-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 回答