保持数组中字符的计数

Keeping Tally of Characters in Arrays

本文关键字:字符 数组      更新时间:2023-10-16

我正在为一项任务编写凯撒密码程序,我已经计划好了大致的理解,但我确定解密密钥的功能不必要地长而乱。

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函数。