2016-12-05 21 views
0

私は自分のコードを完成させることに近いです!私はいくつかの支援をすることができた、私は文字列の文字の数を数えるプログラムを書いた。私の問題は最後に、私のデータを出力するときに来ます。私は、文字列 "AAAABBBC" と入力しますと言うチャーの頻度

A-4 B-3 C-1

する必要があります私の予想出力の代わりに私が手 C-4 C-3 C-1

任意の助けをいただければ幸い、

#include <iostream> 
using namespace std; 




class moose 
{ 
    char inputbuffer[122]; 
    char countbuffer[122]; 
    long count; 
    short index = 0; 

public: 
    char charcount(); 
    char charinput(); 
    char initialize(); 

}; 

int main() 
{ 
    moose obj; 
    obj.initialize(); 
    obj.charinput(); 
    obj.charcount(); 
    system("pause"); 

} 


char moose::initialize() 
{ 
    for (int i = 0; i < 122; i++) 
     countbuffer[i] = 0; 

    return 0; 

} 

char moose::charinput() 
{ 
    cout << "Enter your text and I'll read your characters" << endl; 
    cin.getline(inputbuffer, 132); 
    cin.gcount(); 
    count = cin.gcount(); 
    count--; 
    return 0; 
} 

char moose::charcount() 
{ 
    for (int i = 0; i < count; i++) 
    { 
     if (inputbuffer[i] >= 'a' & inputbuffer[i] <= 'z' || inputbuffer[i] >= 'A' & inputbuffer[i] <= 'Z' || inputbuffer[i] > '0' & inputbuffer[i] <= '9'){ 
      index = inputbuffer[i]; 
      countbuffer[index]++; 

     } 


    } 


    for (int i = 0; i <= 122; i++) { 
     if (countbuffer[i] > 0) 
     { 
      cout << char(index) << " - " << int(countbuffer[i]) << endl; 
     } 
    } 


    return 0; 
} 
+3

を使用しています。スタックオーバーフローを尋ねる前に、コードを一行ずつ進める必要があります。詳しいヘルプは、[小さなプログラムをデバッグする方法(Eric Lippert)](https://ericlippert.com/2014/03/05/how-to-debug-small-programs/)を参照してください。最低限、問題を再現する[最小、完全、および検証可能](http://stackoverflow.com/help/mcve)の例と、その問題を再現するためのデバッガ。 –

+0

最後のループの変数名を注意深く読みます。 – molbdnilo

+0

コードの一般的な品質を改善します。メソッドが何も返さない場合、空白、couter(私は推測する)を整数として設定します。 122などの定数を使用してください –

答えて

1

以下の私のコードは次のように最後のループを変更します。

for (int i = 0; i <= 122; i++) { 
    if (countbuffer[i] > 0) 
    { 
     cout << char(i) << " - " << int(countbuffer[i]) << endl; 
    } 
} 

最初のループでビット単位のANDと論理ANDを変換します(& &)。

ところで、実際に文字のヒストグラムを作成しようとしているので、あなたの場合は、unordered_mapのようなSTLコンテナを使用する方がよいでしょう。一般的に数文字の頻度を格納しようとすると、多くのエントリが最後に0になるため、すべての可能な文字でインデックスされた配列を割り当てるのは無駄です。

+0

こんにちはありがとう!それは簡単な修正でした。私はあなたがSTLコンテナで何を意味するのか分かりません。本当に助けに感謝! – eggo

2
char moose::charcount() 
{ 
    for (int i = 0; i < count; i++) 
    { 
     if (inputbuffer[i] >= 'a' && inputbuffer[i] <= 'z' || inputbuffer[i] >= 'A' && inputbuffer[i] <= 'Z' || inputbuffer[i] > '0' && inputbuffer[i] <= '9'){ 
      index = inputbuffer[i]; 
      countbuffer[index]++; 

     } 


    } 


    for (int i = 0; i <= 122; i++) { 
     if (countbuffer[i] > 0) 
     { 
      cout << char(i) << " - " << int(countbuffer[i]) << endl; 
     } 
    } 


    return 0; 
} 
  1. インデックスの代わりに印刷する "I"。
  2. & - ビット-AND、このような問題を解決する最適なツールは、あなたのデバッガです& &