栈一种容器,遵循先进后出原则,,只能在栈的顶部操作,就像放盘子一样,洗好的盘子叠在上面,需要用时也是先从顶部拿。不允许被遍历。

一、C++stl中的stack语法

  • 1.头文件#include<stack>
  • 2.top()  返回栈顶元素
  • 3.pop()  弹出栈顶元素
  • 4.empty()若栈空返回true,非空返回false
  • 5.size() 返回栈的元素个数,在c++判断里,0是false,非0是true,作用可以上可以替代empty()
  • 6.push() 入栈

栈的经典问题:括号配对问题

描述

现在,有一行括号序列,请你检查这行括号是否配对。

输入
第一行输入一个数N(0<N<=100),表示有N组测试数据。后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S的长度小于10000,且S不是空串),测试数据组数少于5组。数据保证S中只含有"[", "]", "(", ")" 四种字符
输出
每组输入数据的输出占一行,如果该字符串中所含的括号是配对的,则输出Yes,如果不配对则输出No
样例输入
3
[(])
(])
([[]()])
样例输出
No
No
Yes
思路:括号的配对也是遵循栈的工作原理,最里面的括号优先配对。从第一个括号开始遍历,如果是左括号,入栈,如果是右括号并且和栈顶的左括号配对,就出栈一个左括号,通过栈来判断括号是否配对。

AC代码:

#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<math.h>
#include<string>
#include<queue>
#define ll long long
#define inf 0x3f3f3f3f
using namespace std; int t;
string a,b;
int dp[][]; int main()
{
cin>>t;
while(t--)
{
cin>>a;
b="";
int len=a.size();
for(int i=len-;i>=;i--)
b=b+a[i];
//cout<<b<<endl;
memset(dp,,sizeof(dp)); for(int i=;i<len;i++)
{
for(int j=;j<len;j++)
{
if(a[i]==b[j])
dp[i+][j+]=dp[i][j]+;///当i=j=0并且字符相等时,dp[1][1]中的1代表两个字符串比较的字符个数
else
dp[i+][j+]=max(dp[i+][j],dp[i][j+]);
}
}
// printf("%d\n",dp[len][len]);
printf("%d\n",len-dp[len][len]);
} }

二、java里的Stack类

  1. mport java.util.Stack;//导入包
  2. Stack<E> stack=new Stack<E>();//初始化,E表示类,不能是基本类型int之类的
  3. push(x);//入栈
  4. pop();//出栈
  5. peek();//取头元素
  6. empty();//判空,空为true
  7. search(x);//寻找元素x距离栈顶的位置,在栈顶返回1,倒数第二入栈的返回2,如果不在栈中返回-1;

例题:CF990C-Bracket Sequences Concatenation Problem

题解:给出好多好多个括号序列,求某两个序列拼起来能构造出完整的括号匹配序列的 序列对数,可以重复使用。

括号序列分4种情况

1.类似“(((())”和“()(((”这类消去自身已经匹配的括号后剩下的全是左括号

2.类似“(())))”和“())))”这类消去自身已经匹配的括号后剩下的全是右括号

3.类似“()()()()”和“(())()”这类自身能作为完整括号匹配的

4.类似“())(”和“)))((())()”这类消去自身已经匹配的括号后剩下的不是以上任意一种的。无论和其他哪个序列拼接都没办法构造出完整的括号匹配序列。

最终答案=相同剩余单边括号数量的第1、2种情况序列数量之和 + 第3种2

import java.util.Scanner;
import java.util.Stack; public class Main{ public static void main(String []args){
long [] l = new long[300005];
long [] r = new long[300005];
long ok=0;//圆满的序列
long ans=0;
Scanner scan=new Scanner(System.in);
int n;
while(scan.hasNext()) {
ans=0;
ok=0;
n=scan.nextInt();
for(int i=1;i<=n;i++){
Stack<Character> stack=new Stack<Character>();
String s=scan.next();
int len=s.length();
for(int j=0;j<len;j++){
Character x=s.charAt(j);
if(x=='(')//左括号直接入栈
stack.push(x);
if(x==')') {//右括号判断栈顶,如果是(则弹出
if(!stack.empty()&&stack.peek()=='(')
stack.pop();
else//空或者里面也是)
stack.push(x);
}
}
boolean flag=true;//判断这个字符串可不可以作为题目要求的序列
int left=0,right=0;
while(!stack.empty()) {
Character now=stack.peek();
stack.pop();
if(now=='(')
left++;
else
right++;
if(left!=0 && right!=0) {
flag=false;
break;
}
}
if(flag==true) {
if(left==0 && right==0)
ok++;
else if(left!=0)
l[left]++;
else
r[right]++;
}
}
for(int i=1;i<300005;i++) {
ans=ans+(l[i]*r[i]);
l[i]=r[i]=0;
}
ans=ans+ok*ok;
System.out.println(ans);
} }
}

CF990C

stl-stack+括号配对问题的更多相关文章

  1. hdoj 2 括号配对问题【数组模拟实现+STL实现】

    栈遵循先进后出的原则 括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0 ...

  2. Num 15: NYOJ: 题目0002 : 括号配对问题 [ 栈(stack) ]

    原题连接      首先要了解有关栈的一些基本知识,即:      什么是栈,栈有什么作用:        1.什么是栈: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkb ...

  3. ACM:UESTC - 649 括号配对问题 - stack

      UESTC - 649  括号配对问题 Time Limit: 1000MS   Memory Limit: 65535KB   64bit IO Format: %lld & %llu ...

  4. 括号配对问题_栈<stack>

    问题 A: 括号配对问题 时间限制: 3 Sec  内存限制: 128 MB提交: 3  解决: 2[提交][状态][讨论版] 题目描述 现在,有一行括号序列,请你检查这行括号是否配对. 输入 第一行 ...

  5. nyoj 2 括号配对问题(stack)

    括号配对问题 时间限制:3000 ms  |            内存限制:65535 KB 难度:3   描述 现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0& ...

  6. NYOJ之括号配对问题

    括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述     现在,有一行括号序列,请你检查这行括号是否配对. 输入     第一行输入一个数N(0<N&l ...

  7. ACM 括号配对问题

    括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0<N<=1 ...

  8. nyoj 2 括号配对问题

    括号配对问题 时间限制:3000 ms  |            内存限制:65535 KB 难度:3   描述 现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0& ...

  9. 括号配对问题--nyoj-2(栈)

    括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述现在,有一行括号序列,请你检查这行括号是否配对.   输入 第一行输入一个数N(0<N<=10 ...

随机推荐

  1. Gitlab Jenkins WebHook 持续集成配置踩坑记

    Jenkins相关介绍 Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能. 目的 配置Gitla ...

  2. ASP.NET网站权限设计实现(一)——使用PowerDesigner进行数据库设计

    这里用PowerDesigner做一个初步的设计,后面可能会有修改. 1.启动PowerDesigner新建物理数据模型 2.工具栏 3.新建表模型 4.添加第一张表,可以双击表或右键菜单打开下面窗口 ...

  3. 启动ECLIPSE时,提示找到不 eclipse\jre\bin\javaw.exe

    原因:在PATH中未配置 jre\bin目录 %JAVA_HOME%\jre\bin - 无论是用:D:\Asoft\Java\jdk1.7.0_45\jre\bin 还是:D:\Asoft\Java ...

  4. android 更新listview 其中一行的数据显示

    private void updateView(int index){ View v = yourListView.getChildAt(index - yourListView.getFirstVi ...

  5. Oracle 树操作(select…start with…connect by…prior)---转

    原文地址:http://www.cnblogs.com/linjiqin/p/3152674.html -----------

  6. 5.验证用户名是否已经被注册:AJAXC请求

    首先在 web.xml 文件中添加配置信息 <!-- 配置全局的字符集 --> <context-param> <param-name>encode</par ...

  7. 小甲鱼-005python数据类型

    整型:python3整形理论上没有长度限制,很容易进行大数的运算. 浮点型:没有小数点就是整形,有小数点就是浮点型 e记法:科学技术法1.5e3,即1500,1.3e-4即0.0001.3,e记法是浮 ...

  8. linux shell 命令常用快捷键

    下面是一些shell的常用快捷键,快捷键玩熟悉了在一定程度上是可以提高工作效率滴… Ctrl + a 切换到命令行开始 Ctrl + e 切换到命令行末尾 Ctrl + l 清除屏幕内容 Ctrl + ...

  9. [UE4]场景光照改进PostProcessVolume

    PostProcessVolume可以做的效果很多,其中就可以实现太阳光斑效果. Unbound勾上上,就表示不受“PostProcessVolume”组件的大小限制,直接应用到整个世界.如果不勾选, ...

  10. [UE4]事件处理(Handling Events)和委托(Delegate)代码示例(一)

    1. 通过重写虚函数来处理事件 MyTriggerVolume.h 自定义一个Actor类,添加一个 Box 组件作为触发区域,然后通过重写虚函数——NotifyActorBeginOverlap, ...