洛谷P1241 括号序列(c嘎嘎)

题目链接P1241 括号序列 - 洛谷 | 计算机科学教育新生态

题目难度 :普及

解题思路:我们可以开一个栈,然后从左到右遍历,每当遇到左括号就将左括号位置压入栈,遇到右括号就取出栈顶然后与当前遍历到的左括号进行匹配匹配成功,弹出栈并进行标记匹配成功的左右括号的位置,最后进行输出,标记过的直接输出未标记的输出匹配的两个括号。

下面是代码部分

cpp 复制代码
#include<bits/stdc++.h>  // 万能头文件
using namespace std;
typedef long long ll;
const int N = 1010;     
stack<int>st;
string s;
int mark[N];
 
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);
    
    cin >> s;//读入字符串 
    for(int i=0; i< s.length(); i++)
    {
    	if(s[i] == '(' || s[i] == '[') st.push(i);//左括号压入栈 
    	if(!st.empty())
    	{
    		int j = st.top();//取出栈顶 
    		if((s[i] == ')' && s[j] == '(')|| (s[i] == ']' && s[j] == '['))//判断是否匹配匹配则进行标记 
    		{
    			mark[i] = mark[j] = 1;//匹配成功标记位置 
    			st.pop();//弹出栈继续判断 
			}
		}
	}
	for(int i = 0; i<s.length(); i++)
	{
		if(mark[i] == 1) cout<<s[i];//标记过直接输出 
		else
		{
			if(s[i] == '(' || s[i] == ')') cout<<"()";
			else cout<<"[]";
		}
    }    
    
	
    return 0;  
}
 
相关推荐
txinyu的博客11 小时前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
搞笑症患者12 小时前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER12 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
予枫的编程笔记12 小时前
【Java集合】深入浅出 Java HashMap:从链表到红黑树的“进化”之路
java·开发语言·数据结构·人工智能·链表·哈希算法
mjhcsp12 小时前
C++ 后缀数组(SA):原理、实现与应用全解析
java·开发语言·c++·后缀数组sa
hui函数12 小时前
如何解决 pip install 编译报错 ‘cl.exe’ not found(缺少 VS C++ 工具集)问题
开发语言·c++·pip
快手技术12 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱12 小时前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄12 小时前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码12 小时前
leetcodeD3
数据结构·算法