我正在用c ++编写一个简单的应用程序,用于计算总和的频率(即当你掷骰子时)。程序完全运行,甚至产生正确的结果,但在执行结束时,Windows告诉我程序停止工作。
我正在使用Dev-Cpp 5.11和TDM-GCC 4.9.2 32位版本编译器来创建和编译后面的代码。
#include<iostream>
#include<limits>
#include<string>
using namespace std;
const int int_min = numeric_limits<int>::min(),
int_max = numeric_limits<int>::max();
int getint(string ln, int lower, int upper){
int input = 0;
cout << ln;
if(cin >> input && input >= lower && input <= upper){
cin.clear();
cin.ignore(80,'\n');
}else{
cout << "ERR:\tINVALID\nDesc:\t";
if(cin.good() && (input <= lower || input >= upper))
cout << "OUT OF BOUNDS [" << lower << " <= val <= " << upper << "]";
else
cout << "NAN";
cout << "\n\n";
cin.clear();
cin.ignore(80,'\n');
return getint(ln,lower,upper);
}
return input;
}
int main(){
int
n = getint("Input(n) > ",1,int_max),
a = getint("Input(a) > ",0,int_max),
b = getint("Input(b) > ",a,int_max),
r = b - a + 1,
t = n * (r - 1) + 1;
int
pos = 0,
sum = 0,
val[n],
frq[t];
for(int i = 0; i < n; i++)
val[i] = 0;
for(int i = 0; i < t; i++)
frq[i] = 0;
while(pos < n){
pos = 0;
sum = 0;
for(int i = 0; i < n; i++)
sum += val[i];
frq[sum]++;
val[pos]++;
while(val[pos] >= r){
val[pos++] = 0;
if(pos <= n - 1)
val[pos]++;
}
}
for(int i = 0; i < t; i++){
cout << "frq(" << i + n << ")\t|\t" << frq[i] << endl;
}
return 0;
}
答案 0 :(得分:1)
循环while(val[pos] >= r){...
可能会一直循环,直到pos
远远超过n
,这是val[]
的大小,因此将零写入数组的末尾。这是灾难性的。您需要执行while(pos < n && val[pos] >= r){...