-1

スタックを使用して適切にネストするために、角かっこで構成されるユーザー入力を検証するプログラムを作成しようとしています。STLコンテナや再帰を使用せずにこれを実行しようとしています。私はやや障害にぶつかりました、そして私は正しい方向への少しの微調整を探しています。少し親密だと思いますが、単純化しすぎている気がします(自習で学んでいるところです)

これが私がこれまでに持っているものです:

#include <iostream>
#include <string>
#include "ArrayStack.h"
using namespace std;

bool test(char *argg);

int main()
{
    string input;
    int size = 50;

    cout << "enter here: ";
    getline(cin, input);
    for (int i = 0; i < size; i++)
        test(input[i]);
}

bool test(char *argg)
{
    ArrayStack S;
    char D;
    while ( *argg ) {
        switch( *argg ) {

            case '[': case '{': case '(':
                S.push( *argg );
                break;

            case ']':
                if( S.isEmpty() )
                    return false;
                D = S.pop();
                if( D!='[' )
                    return false;
                break;

            case '}':
                if( S.isEmpty() )
                    return false;
                D = S.pop();
                if( D!='{' )
                    return false;
                break;

            case ')':
                if( S.isEmpty() )
                    return false;
                D = S.pop();
                if( D!='(' )
                   return false;
                break;

            default:
                return false;
        }// end switch
                   argg++;
    }// end while

    return S.isEmpty(); // return true if reach here with empty stack

}

事前にご協力いただきありがとうございます

4

2 に答える 2

0

どちらかといえば、あなたはそれを複雑にしすぎています

char inverse(char c){
   if(c==']') return '[';
   if(c=='}') return '{';
   if(c==')') return '('; 
   return c;
}
int stillvalid(char c, ArrayStack &stack){
   if(strchr("[{(", c))
        stack.push(c);
    else if(strchr("]})", c))
        if(stack.isEmpty() || inverse(c) != stack.pop())
            return 0;
    return 1;
}

int main(){
    int c;
    ArrayStack stack;
    while((c=getchar())!=EOF){
       if(!stillvalid((char)c, stack)){
           printf("bad\n");
           exit(0);
       }
    }
    printf("good\n");
    return 0;
}

必要なのはそれだけです。

于 2011-12-04T07:26:27.083 に答える
0

入力を使用してコードを手でトレースしますmyfunc(42);

キャラクターごとに何が起こるか観察してください。それはあなたのエラーを指摘するはずです。

于 2011-12-04T12:04:37.927 に答える