C 中的数学问题

Math issue in C++

本文关键字:问题      更新时间:2023-10-16

我正在制作一个代码,其中您输入两个数字,a和b,然后计算出a内部的b,然后用剩余的数量显示此数字。尽管当a = -2147483648和b = 10时,数学错误时,我也可以找出问题所在,即使是debugger.thank您!

#include <iostream>
#include <cmath>
int main() {
    int multiple, a, b, rest;
    std::cin >> a >> b;
    if (a > 0)
    {
        multiple = floor(a / b);
        rest = a - (multiple * b);
    }
    else
    {
        multiple = floor((a - b) / b);
        rest = (multiple*b - a);
    }
    std::cout << multiple << " " << rest << std::endl;
}

结果提倡-214748365 2结果给定的214748363 -18

您期望从程序中给出:(-16)/6 = -3乘以6和 2。它只是将16除以6,最后使减数为-4。我对您的代码进行了一些更改,以实现您的目的。我们必须制定一个程序以按照您想要的方式服务。因此,因为当A&lt时,您的乘数为减去;0,我们需要将(-1)添加到它。SO 6*(多人-1) 2 == 6*(-2-1) 2 == -16 so:

#include <iostream>
using namespace std;
int main()
{
    int multiple, a, b, rest;
    std::cin >> a >> b;
    if (a > 0)
    {
        multiple = a / b;
        rest = a - (multiple * b);
    }
    else
    {
        multiple = a / b - 1;
        rest = -(multiple*b - a);
    }
    std::cout << multiple << " " << rest << std::endl;
    return 0;
}

运行:

./a.out 
-2147483648
10
-214748365 2
#include <iostream>
#include <cmath>
main (){
 double multiple, a, b, rest;
 std::cin >> a >> b;
 // you have to make sure b not equal zero 
 if (b != 0){
    // when a is bigger then many b's can be inside a 
    if (a > b){
       multiple = floor (a / b);
       rest = a - (multiple * b);
    }
    // when b is bigger then no b's can be inside a 
    else if (a < b){
             multiple = 0;
             rest = a;
    }
    // when a = b  then it only one b can be inside a 
    else{
          multiple = 1;
          rest = 0;
    }
  }
 std::cout << multiple << " " << rest << std::endl;

它的所有情况都可以计算A内部可以计算多少个B,您可以尝试%操作员,它将更好