zoukankan      html  css  js  c++  java
  • 判断一个字符串是否为嵌套字符串,如{([()])}, {()}(0){}[{}]

    嵌套判断标准:{}[]()特定字符匹配

    {([()])} 是

    {()}(0){}是

    {[}] 不是

    结束标志:

    如果字符串中含有其他非特定符号时,嵌套与否的定义为:迭代字符为,且栈中没有特定字符。(本文代码假设条件)

    如果字符串中只有特定字符,嵌套与否的标准为:迭代字符为,且栈中为空。

    #include <iostream>
    #include <stack>
    
    using namespace std;
    
    void charMatch(const char* str)
    {
        stack<char> charStack;
        if(str==NULL){
            cout << "the string is NULL..." <<endl;
            return;
        }
        while(*str != ''){
            while(*str != '' && *str != ']' && *str != '}' && *str != ')'){
                cout << *str <<endl;
                charStack.push(*str);
                ++str;
            }
            if(*str == ']'){
                while(!charStack.empty() && charStack.top()!= '['){
                    charStack.pop();
                }
                if(charStack.empty()){
                    cout << "string is not match to nest" <<endl;
                    return;
                }
                if(charStack.top() == '['){
                    charStack.pop();
                }
            }
            if(*str == '}'){
                while(!charStack.empty() && charStack.top()!= '{'){
                    charStack.pop();
                }
                if(charStack.empty()){
                    cout << "string is not match to nest" <<endl;
                    return;
                }
                if(charStack.top() == '{'){
                    charStack.pop();
                }
            }
            if(*str == ')'){
                while(!charStack.empty() && charStack.top()!= '('){
                    charStack.pop();
                }
                if(charStack.empty()){
                    cout << "string is not match to nest" <<endl;
                    return;
                }
                if(charStack.top() == '('){
                    charStack.pop();
                }
            }
            ++str;
        }
        if(*str == '' && !charStack.empty()){
            while(!charStack.empty() && charStack.top() != '[' && charStack.top() != '{' && charStack.top() != '('){
                charStack.pop();
            }
            if(charStack.empty()){
                cout << "string is match to nest" <<endl;
                return;
            }
            if(charStack.top() == '[' || charStack.top() == '{' || charStack.top() == '('){
                cout << "string is not match to nest" <<endl;
                return;
            }
        }
        if(*str == '' && charStack.empty()){
            cout << "string is match to nest" <<endl;
                return;
        }
    }
    
    int main(){
        string str = "({k[]})[";
        cout << str <<endl;
        charMatch(str.c_str());
        return 0;
    }
  • 相关阅读:
    poj 2778 AC自己主动机 + 矩阵高速幂
    Web Services 指南之:Web Services 综述
    SQL多表连接查询(具体实例)
    HibernateUtil
    哈夫曼编码问题再续(下篇)——优先队列求解
    MySQL Merge存储引擎
    程序的入口及AppDelegate窗体显示原理
    几个免费的DNS地址
    kettle与各数据库建立链接的链接字符串
    【转】利用optimize、存储过程和系统表对mysql数据库表进行批量碎片清理释放表空间
  • 原文地址:https://www.cnblogs.com/lifeinsmile/p/5245748.html
Copyright © 2011-2022 走看看