我正在为一项任务编写凯撒密码程序,我已经计划好了大致的理解,但我确定解密密钥的功能不必要地长而乱。
while(inFile().peek != EOF){
inFile.get(character);
if (character = 'a'|| 'A')
{ aCount++; }
else if (character = 'b' || 'B')
{ bCount++; }
等等。
如果可能的话,我可以用什么方法把它变成一个数组?
您可以使用以下代码:
int count [26] = {0};
while(inFile().peek != EOF){
inFile.get(character);
if (int (character) >=65 || int (character) <=90)
{ count [(int (character)) - 65] ++; }
else if (int (character) >=97 || int (character) <=122)
{ count [(int (character)) - 97] ++; }
}
附言:这是检查每个字符的ASCII值,然后在所有字符的数组中增加其相应的元素,A/A的索引为0,B/B的索引为1,依此类推。希望这能帮助。。。
p.S.-您的代码中有一个错误,=
是赋值运算符,==
是条件运算符,并且您没有在if
语句中赋值,您检查条件所以总是使用==
来检查相等性。。。
您可以按照以下方式使用数组
int letterCount['z'] = {0}; //z is the highest letter in the uppercase/lowercase alphabet
while(inFile().peek != EOF){
inFile.get(character);
if (character > 'A' && character < 'z')
letterCount[character]++;
}
你也可以使用像这样的哈希图
#include <unordered_map>
std::unordered_map<char,int> charMap;
while(inFile().peek != EOF){
inFile.get(character);
if (charMap.find(character) == charMap.end())
charMap[character] = 1;
else
charMap[character] = charMap[character] + 1;
}
如果您不知道,hashmap的作用是数组,其中索引可以是您喜欢的任何类,只要它实现了hash函数。