• 判断一个字符串是否为嵌套字符串,如{([()])}, {()}(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;
    }
  • 相关阅读:
    ApacheTika解析Word文档
    Oracle中生成随机数的函数
    实现Android和PC之间的蓝牙通信(转载)
    以C#编写的Socket服务器的Android手机聊天室Demo
    初识SVM
    一些编程的小练手
    c#连接MYSQL数据库的两种方法
    Doxygen+Graphviz用来画程序结构图
    C#+MYSQL数据库操作(附源码)
    [转]Use PowerShell to Manage Lists, Views, and Items in SharePoint(使用PowerShell管理列表、视图、列表项)
  • 原文地址:https://www.cnblogs.com/lifeinsmile/p/5245748.html
Copyright © 2020-2023  润新知