C++取余符号%的实现示例

 更新时间:2026年02月27日 15:45:48   作者:CSDN_RTKLIB  
本文主要介绍了C++取余符号%的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

c++的%是取余运算符是吗,如果做取余运算正数负数都可以直接使用,如果是取模运算负数时就要自己调整一下是吧

一、核心结论:C++的%是取余运算符(而非数学上的模运算符)

C++中的%运算符实现的是取余运算(商向取整),而非数学意义上的模运算(商向负无穷取整)。这一点是理解后续问题的关键。

二、关于“正数/负数能否直接使用%”的说明

1. 正数场景:直接用,无任何问题

当被除数a和除数b均为正整数时,取余和模运算的结果完全一致,%运算符的结果就是你想要的(无论是取余还是模运算)。
示例:

#include <iostream>
using namespace std;

int main() {
    cout << 7 % 3;  // 输出1(取余/模运算结果一致)
    cout << 9 % 6;  // 输出3(取余/模运算结果一致)
    return 0;
}

2. 负数场景:语法上可以直接用,但结果是取余(符号与被除数一致)

C++11及以后的标准明确规定:a % b的结果满足**(a / b) * b + (a % b) = a,其中a / b向零取整**(截断小数部分)。因此,%的结果符号与**被除数a**一致。
示例:

#include <iostream>
using namespace std;

int main() {
    cout << -7 % 3;   // 输出-1(被除数-7为负,结果为负)
    cout << 7 % -3;   // 输出1(被除数7为正,结果为正)
    cout << -7 % -3;  // 输出-1(被除数-7为负,结果为负)
    return 0;
}

这里的关键是:负数场景下%的结果是取余,而非模运算。如果你的业务逻辑需要的是数学上的模运算(结果与除数同符号),直接用%会得到不符合预期的结果(比如-7 % 3得到-1,但模运算需要的是2)。

三、如果需要在C++中实现数学上的模运算(负数需手动调整)

若要得到模运算的结果(结果与除数同符号,商向负无穷取整),需要对%的结果进行手动调整。核心思路是:将取余结果加上除数的绝对值,再取一次余,确保结果落在[0, |b|)范围内

1. 通用调整公式

模运算结果 = (a % b + b) % b

这个公式对正数、负数、除数正负都适用,能稳定得到数学上的模运算结果。

2. 代码实现(封装成模运算函数)

#include <iostream>
using namespace std;

// 实现数学上的模运算(结果与除数同符号)
int mod(int a, int b) {
    if (b == 0) {
        // 除数不能为0,可根据需求抛异常或终止程序
        cerr << "除数不能为0" << endl;
        exit(1);
    }
    return (a % b + b) % b;
}

int main() {
    cout << mod(-7, 3);   // 输出2(模运算:与除数3同符号)
    cout << mod(7, -3);   // 输出-2(模运算:与除数-3同符号)
    cout << mod(7, 3);    // 输出1(正数场景与取余一致)
    cout << mod(-7, -3);  // 输出-1(模运算:与除数-3同符号)
    return 0;
}

四、补充注意事项

  1. 除数不能为0:无论是%取余还是手动实现的模运算,除数b都不能为0,否则会触发未定义行为(程序崩溃或异常)。
  2. 浮点数不支持%:C++的%运算符仅适用于整数类型(int、long等),如果要对浮点数做类似运算,需使用<cmath>头文件中的fmod()函数(但浮点数的模运算逻辑与整数不同)。

总结

  1. C++的%是取余运算符(商向零取整),正数场景可直接用,负数场景语法上也能直接用,但结果是取余(符号与被除数一致);
  2. 若需要数学上的模运算(结果与除数同符号),负数场景下需用(a % b + b) % b手动调整结果;
  3. 无论取余还是模运算,都要保证除数不为0。

到此这篇关于C++取余符号%的实现示例的文章就介绍到这了,更多相关C++取余符号%内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Qt解析XML的三种常见方法实现与比较

    Qt解析XML的三种常见方法实现与比较

    XML是一种可扩展的标记语言,用于存储和传输结构化数据,广泛应用于配置、数据交换和Web服务等领域,本文主要介绍了Qt解析XML的三种常见方法实现和性能对比,需要的可以了解下
    2025-06-06
  • C语言实现贪吃蛇游戏(命令行)

    C语言实现贪吃蛇游戏(命令行)

    这篇文章主要为大家详细介绍了C语言命令行实现贪吃蛇游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • C/C++ 获取Windows系统的位数32位或64位的实现代码

    C/C++ 获取Windows系统的位数32位或64位的实现代码

    这篇文章主要介绍了C/C++ 获取Windows系统的位数32位或64位的实现代码的相关资料,希望通过本文能帮助到大家,让大家实现这样的功能,需要的朋友可以参考下
    2017-10-10
  • 浅析string 与char* char[]之间的转换

    浅析string 与char* char[]之间的转换

    与char*不同的是,string不一定以NULL('\0')结束。string长度可以根据length()得到,string可以根据下标访问。所以,不能将string直接赋值给char*
    2013-10-10
  • 详谈C++ socket网络编程实例(2)

    详谈C++ socket网络编程实例(2)

    这篇文章主要为大家介绍了C++ socket网络编程实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • C语言实现简易文本编译器

    C语言实现简易文本编译器

    这篇文章主要为大家详细介绍了C语言实现简易文本编译器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • Python/Java/JS语言调用C/C++库的底层原理详解

    Python/Java/JS语言调用C/C++库的底层原理详解

    开发过程中很多时候都会遇到调用C++动态库dll的需求,下面这篇文章主要介绍了Python/Java/JS语言调用C/C++库的底层原理,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2026-01-01
  • 深入了解C++11中promise和future的使用

    深入了解C++11中promise和future的使用

    C++11中promise和future机制是用于并发编程的一种解决方案,用于在不同线程完成数据传递(异步操作)。Promise和Future提供了访问异步操作结果的机制,可以在线程之间传递数据和异常消息。本文就来聊聊二者的使用,希望对大家有所帮助
    2022-11-11
  • C语言游戏必备:光标定位与颜色设置的实现方法

    C语言游戏必备:光标定位与颜色设置的实现方法

    本篇文章是对c语言中光标定位与颜色设置的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++的matlab接口转换方法详解

    C++的matlab接口转换方法详解

    这篇文章主要为大家详细介绍了C++的matlab接口转换方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03

最新评论