[英]Double/Integer use and data narrowing within a Range-Based for loop
我正在通过Bjarne Stroustrup的编程原则和实践工作,我遇到了困难。 我目前正在阅读Vector,并已介绍到基于范围的for循环。 下面我有一些代码,从我的眼睛看,似乎正在阅读一个双重进入INT; 我认为这会导致缩小范围。
int main()
{
vector<double> temps; // temperatures
for (double temp; cin >> temp; ) // read into temp
temps.push_back(temp); // put temp into vector
// compute mean temperature:
double sum = 0;
for (int x : temps) sum += x;
cout << "Average temperature: " << sum / temps.size() << '\n';
// compute median temperature:
sort(temps); // sort temperatures
cout << "Median temperature: " << temps[temps.size() / 2] << '\n';
keep_window_open();
return 0;
}
在尝试了几次不同的输入后,我得出结论,这确实在缩小。 我正在创建一个双精度矢量,而不是for(int x:temps)循环,将第一个元素放在temp中,将它放在x中,处理它而不是递增到下一个元素并重复。 因为元素(双精度)被读入x(整数),导致变窄。
我的主要问题是,如果我确实是正确的,它正在缩小向量中的元素(可能它实际上没有读入x并且int x正在描述其他内容),我可以简单地将(int x:temps)替换为for (double x:temps)以避免这种缩小,或者是在基于范围的for循环参数中强制使用整数(可能是这样设计的)。 有任何想法,谢谢。
for
循环变量(它的任何版本)。 floor
操作)。 请看一下 C ++的转换规则:
如果转换是从浮点类型转换为整数类型,则会截断该值(删除小数部分)。 如果结果位于类型的可表示值范围之外,则转换会导致未定义的行为。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.