题目描述:
根据邮件的重量和用户是否选择加急计算邮费。计算规则:重量在1000克以内(包括1000克), 基本费8元。超过1000克的部分,每500克加收超重费4元,不足500克部分按500克计算;如果用户选择加急,多收5元。
输入:
输入一行,包含整数和一个字符,以一个空格分开,分别表示重量(单位为克)和是否加急。如果字符是y,说明选择加急;如果字符是n,说明不加急。
输出:
输出一行,包含一个整数,表示邮费。
根据上述题目,初步编写C++程序如下:
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int weight,money;
char ch;
cin>>weight>>ch;
if(weight<=1000)
money=8;
if(weight>1000)
money=8+4*ceil((weight-1000)/500);
if(ch=='y')
money+=5;
cout<<money;
return 0;
}
编译可以通过,输入数据“1200 y”验证,但结果却是错误的!分析代码,发现问题出在ceil((weight-1000)/500)上,由于weight为int类型,所以(weight-1000)/500结果为int类型,即为0,因而用ceil()向上取整结果也为0。
修改方法:
(weight-1000)乘以1.0即可,此时(weight-1000)*1.0/500结果为0.4,再向上取整为1,于是结果就正确了。
结论:当一个题目显式都是int类型,但计算过程中可能产生float等浮点型时,要格外注意取整问题,防止ceil()函数中参数为int类型。