在数组中保持字符符号

时间:2016-07-30 21:26:22

标签: c++ arrays file variable-assignment caesar-cipher

我正在为一项任务开发Caesar Cipher程序,并且我已经计划好了一般性的理解,但是我确定解密密钥的功能不必要地冗长而且很混乱。

while(inFile().peek != EOF){
      inFile.get(character);
      if (character = 'a'|| 'A')
         { aCount++; }
      else if (character = 'b' || 'B')
         { bCount++; }
等等等等。

如果有可能,我可以把它变成一个数组吗?

2 个答案:

答案 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作为一个数组起作用,索引可以是你喜欢的任何类,只要它实现了一个哈希函数。