我该如何计算整数的百分比?
例如,如果我想从一个数字中得到30%,如果我使用这段代码示例,我将得到错误的答案:
int number = 250;
int result = (number / 100) * 30;
结果将会是60
,而真正的答案是75
,有没有办法计算出来?
我该如何计算整数的百分比?
例如,如果我想从一个数字中得到30%,如果我使用这段代码示例,我将得到错误的答案:
int number = 250;
int result = (number / 100) * 30;
结果将会是60
,而真正的答案是75
,有没有办法计算出来?
先乘后除:
int result = number * 30 / 100;
你得到的结果是因为使用整数类型进行除法运算产生的整数结果,例如250/100等于2。如果在除法之前先进行乘法运算,你仍然会得到一个整数结果,但至少在中间步骤中不会丢失数据。如果你需要处理非常大的数字,则有可能溢出int
所允许的范围。
另一种方法是使用浮点数运算,在这种情况下,除法可以产生整数的分数:
int result = number * 0.30;
这可能会产生意外的结果,所以最好像上面那样只使用整数。或者写成3.0/10
而不是0.30
。
int
的范围怎么办?例如,考虑以下代码:int number = 1000000000
; int result = number * 30 / 100;。由于溢出,
result` 不会是 300000000。 - LRDPRDX可以像其他人建议的那样交换操作数,但是如果您不想这样做,还有另一种解决方案:
int number = 250;
int result = static_cast<double>(number) / 100 * 30;
假设数字比较小,你可以直接反过来:
int result = (number * 30) / 100;
(括号不是必需的,但有助于澄清)。
如果其中任意一个数字超过了数百万,则此方法无法正常工作,但对于小于该范围的数字来说应该是可以的。
试一下这个,
int number = 250;
float result = number * (float)(30/100.0);
30/100.0
转换为浮点数?它本身不就是浮点数吗? - SpongeBobFan另一种可能性,在处理32位数字时在Windows中很好。
int num = 750;
int result;
result = MulDiv(num,30,100);
https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-muldiv
double number , result;
cout << "Enter the number:";
cin >> number;
result = number * 30.0 / 100;
cout << "Result = " << result << endl;
你会得到你的答案...
你需要执行浮点数运算,否则编译器会将这里的所有算术操作都作为整数进行。
你可以尝试
int result = (number / 100.0) * 30;
float number = 250;
float result = (number / 100.0) * 30
只是在那里放置带小数点的100.0可能就足够了。
因为如果按照您的方式进行计算,250/100在整数中等于20(您只能将100放入200两次,整数不关心剩下的50),然后乘以30=60。
现在我考虑一些解决方案:
int number = 250;
int result = number * 100;
result = (result / 100) * 30;
result /= 100;
分数/物品*30 例如;
15%
int score, items;
cout<<"input your score"<< score<<endl;
cin>>score;
cout<<"input number of items"<<items<<endl;
cin>>items;
float total=score/items*15
cout<<"you got "<<total<<""<<endl;