我正在为一项任务开发Caesar Cipher程序,并且我已经计划好了一般性的理解,但是我确定解密密钥的功能不必要地冗长而且很混乱。
while(inFile().peek != EOF){
inFile.get(character);
if (character = 'a'|| 'A')
{ aCount++; }
else if (character = 'b' || 'B')
{ bCount++; }
等等等等。
如果有可能,我可以把它变成一个数组吗?
答案 0 :(得分:0)
您可以使用以下代码:
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] ++; }
}
P.S。这是检查每个字符的ASCII值,然后在所有字符的数组中递增其各自的元素,其中A / a为0,B / b为1,依此类推。 希望这会有所帮助...
P.S。 - 您的代码出错,=
是赋值运算符,==
是条件运算符,您没有在if
语句中赋值,检查条件...... < strong>所以总是使用==
检查是否相等 ...
答案 1 :(得分:0)
您可以按以下方式使用数组
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作为一个数组起作用,索引可以是你喜欢的任何类,只要它实现了一个哈希函数。