0

プログラムをデバッグすると、アスタリスク付きの行を出力するときにランダムな文字列が出力されます。

int main ()
{
string inputPuzzle;
cout << "Enter a word or set of words: ";
getline(cin, inputPuzzle);
char* puzzle = new char[inputPuzzle.size()+1];
memcpy(puzzle, inputPuzzle.c_str(), inputPuzzle.size()+1);
puzzle[inputPuzzle.size()+1] = '';
int strikes = 0;
char userInput;
char* userSoln = new char[inputPuzzle.size()];
for (int i = 0; i < inputPuzzle.size(); i++)
{
    userSoln[i] = '-';
    if (puzzle[i] == ' ')
    {
        userSoln[i] = ' ';
    }
}
bool solved = false;
int numberOfLetters;
for (;;)
{
    numberOfLetters = 0;
    cin >> userInput;
    for (int i = 0; i < inputPuzzle.size(); i++)
    {
        if (userInput == puzzle[i])
        {
            numberOfLetters++;
            userSoln[i] = puzzle[i];
        }
    }
    if (numberOfLetters == 0)
    {
        cout << "There are no " << userInput << "'s\n" ;
        strikes++;
    }
    else
    {
        cout << "There are " << numberOfLetters << " " << userInput << "'s\n";
    }
    if (userSoln == puzzle)
    {
        break;
    }
    if (strikes == 10)
    {
        break;
    }
    **cout << "PUZZLE: " << userSoln << "\n";**
    cout << "NUMBER OF STRIKES: " << strikes << "\n";
}
if (strikes == 10)
{
    cout << "Sorry, but you lost. The puzzle was: " << puzzle;
}
else
{
    cout << "Congratulations, you've solved the puzzle!!! YOU WIN!!!!!";
    }
}

cin バッファをクリアしようとしましたが、何もしていません。必要なインクルード ファイル (文字列と iostream) もすべて持っているので、それは問題ではなく、メイン メソッドの上に名前空間 std があります。

4

2 に答える 2

0

これは有効な文字定数ではありません。

puzzle[inputPuzzle.size()+1] = '';

終了文字を意図している場合は、

puzzle[inputPuzzle.size()+1] = '\0';

あるいは単に

puzzle[inputPuzzle.size()+1] = 0;

または、これらの行の両方を置き換えることができます

memcpy(puzzle, inputPuzzle.c_str(), inputPuzzle.size()+1);
puzzle[inputPuzzle.size()+1] = '';

strcpy

strcpy(puzzle, inputPuzzle.c_str());

編集:

userSolnまた、印刷する前に終了文字を の最後に置く必要があります。

userSoln[ inputPuzzle.size() ] = '\0';
于 2013-04-15T18:11:36.340 に答える