我正在通过char c = cin.get()
进行字符统计。我的输出示例如下:
a:53
b:32
c:29 等..
对于其中一个字母,我得到一个非常大的9位数字。然后当我使用另一个包含更多字符的输入文件时,这些数字是6位数而且太大而不准确。对这种表型的任何想法?
再次,对不起,这是学期末的关键时刻。我很感激那里的任何帮助。
int main (int argc, char *argv[])
{
int count [26] = { };
char alpha [26] = { };
char c;
c = cin.get();
while(!cin.eof())
{
if (isalpha(c))
{
c = tolower(c);
}
count [ c - 'a']++;
alpha [ c - 'a'] = c;
c = cin.get();
}
for ( int i = 0; i<26; i++ )
{
cout << alpha[i] << ":" << count[i] << endl;
}
} //end main
这是输出:(已编辑)
a:224
b:50
c:70
d:20
e:167772180
f:10
g:40
h:66
i:28
这是输入:(已编辑)
aaaaaaaaAAAAAaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaAAAaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaBBBB
进行了这些更改,但它仍然“悬挂”:
c = cin.get();
while(c=cin.get())
{
c = tolower(c);
if (isalpha(c))
continue;
count [ c - 'a']++;
alpha [ c - 'a'] = c;
}
for ( int i = 0; i<26; i++ )
{
cout << alpha[i] << ":" << count[i] << endl;
}
} //end main
答案 0 :(得分:4)
如果输入文件包含除字母以外的任何内容,则可能发生任何事情,因为您正在使用超出范围的索引访问数组。也许你的意思是:
while(!cin.eof())
{
if (isalpha(c))
{
c = tolower(c);
count [ c - 'a']++;
alpha [ c - 'a'] = c;
}
c = cin.get();
}
E.g。当您的数据包含换行符(10)时,您正在访问索引为10 - 97 = -87的alpha
。这可能会将10写入count[4]
的最重要字节。