首页 > 其他分享 >18933 括号匹配问题

18933 括号匹配问题

时间:2024-10-14 22:49:26浏览次数:12  
标签:匹配 string 18933 markers 括号 字符串 input stack

### 思路
1. **输入处理**:读取输入的字符串。
2. **匹配括号**:使用栈来匹配括号,记录无法匹配的左括号和右括号的位置。
3. **标注输出**:根据记录的位置,生成标注字符串,输出原始字符串和标注字符串。

### 伪代码
```
function process_string(input):
    stack = []
    markers = [' '] * len(input)

    for i from 0 to len(input) - 1:
        if input[i] == '(':
            stack.push(i)
        elif input[i] == ')':
            if stack is not empty:
                stack.pop()
            else:
                markers[i] = '?'

    while stack is not empty:
        markers[stack.pop()] = '$'

    return input, markers.join('')

function main():
    while input is not EOF:
        input = read_input()
        original, markers = process_string(input)
        print(original)
        print(markers)
```

### C++代码
 

#include <iostream>
#include <stack>
#include <cstring>
using namespace std;

void process_string(const string& input) {
    stack<int> s;
    string markers(input.length(), ' ');

    for (int i = 0; i < input.length(); ++i) {
        if (input[i] == '(') {
            s.push(i);
        } else if (input[i] == ')') {
            if (!s.empty()) {
                s.pop();
            } else {
                markers[i] = '?';
            }
        }
    }

    while (!s.empty()) {
        markers[s.top()] = '$';
        s.pop();
    }

    cout << input << endl;
    cout << markers << endl;
}

int main() {
    char s[205];
    while (scanf("%s", s) != EOF) {
        process_string(s);
    }
    return 0;
}

### 总结
1. **输入处理**:读取并存储输入字符串。
2. **匹配括号**:使用栈来匹配括号,记录无法匹配的括号位置。
3. **标注输出**:根据记录的位置,生成标注字符串,输出原始字符串和标注字符串。

标签:匹配,string,18933,markers,括号,字符串,input,stack
From: https://blog.csdn.net/huang1xiao1sheng/article/details/142930985

相关文章

  • 高清图解28个高并发之数据结构/数据结构场景匹配技巧分析(高并发精通篇一)
    ​Java集合以ArrayList、LinkedList、HashSet、TreeSet和HashMap等组件为核心,构筑了强大而灵活的数据结构体系。这些组件精心设计以满足不同的性能和功能需求,如ArrayList的动态数组支持快速随机访问,而LinkedList的双向链表结构则擅长于频繁的插入和删除操作。HashSe......
  • 28. 找出字符串中第一个匹配项的下标 Golang实现
    题目描述:给你两个字符串haystack和needle,请你在haystack字符串中找出needle字符串的第一个匹配项的下标(下标从0开始)。如果needle不是haystack的一部分,则返回-1。示例1:输入:haystack="sadbutsad",needle="sad"输出:0解释:"sad"在下标0和6处匹配。......
  • 二分图最大匹配-匈牙利算法
    二分图最大匹配设G为二分图,若在G的子图M中,任意两条边都没有公共节点,那么称M为二分图G的一组匹配。在二分图中,包含边数最多的一组匹配称为二分图的最大匹配。交替路:从一个未匹配点出发,依次经过非匹配边、匹配边、非匹配边…形成的路径叫交替路。增广路:从一个未匹配点......