题意:

      问你括号匹配是否唯一,三种字符'(','?',')',问号可以变成任何字符。

思路:

      首先我们要学会判断当前串是否成立?怎么判断?我的方法是跑两遍,开三个变变量

s1 s2 s3 分别存(?)他们三个的当前个数,然后先正着跑,只要s1 + s2 < s3那么就不成立,然后在倒着跑只要 s3 + s2 < s1也不成立,如果两变跑完了都成立,那么当前的串就是成立的,对于怎么判断他的唯一性,我采用的是暴力的方法,每次遇到"?"就把他变成(和)如果两个都满足。那么就直接是多组解,不然继续找下一个问号,还有就是我真心觉得这么做会超时的,虽然AC了,可能是数据水。


#include<stdio.h>
#include<string.h>
#include<stack>

using namespace
std; char str[1000010]; bool ok()
{
int
s1 ,s2 ,s3 ,mk ,l ,i;
l = strlen(str);
s1 = s2 = s3 = 0;
for(
i = 0 ;i < l;i ++)
{
if(
str[i] == '(') s1 ++;
if(
str[i] == '?') s2 ++;
if(
str[i] == ')') s3 ++;
if(
s1 + s2 < s3) return 0;
}

s1 = s2 = s3 = 0;
for(
i = l - 1 ;i >= 0;i --)
{
if(
str[i] == '(') s1 ++;
if(
str[i] == '?') s2 ++;
if(
str[i] == ')') s3 ++;
if(
s2 + s3 < s1)return 0;
}
return
1; } int main ()
{
int
mk1 ,mk2 ,l ,mk ,i;
while(~
scanf("%s" ,str))
{

l = strlen(str);
if(
l % 2) {puts("None");continue;}
if(!
ok()) {puts("None");continue;}
for(
mk = i = 0 ;i < l && !mk ;i ++)
{
if(
str[i] == '?')
{

str[i] = '(';
ok()? mk1 = 1 : mk1 = 0;
str[i] = ')';
ok()? mk2 = 1 : mk2 = 0;
str[i] = '?';
if(
mk1 && mk2) mk = 1;
}
}

mk ? puts("Many"): puts("Unique");
}
return
0;
}

hdu4915 判断括号匹配的更多相关文章

  1. Python 用栈判断括号匹配

    #!/usr/bin/python # -*- coding: UTF-8 -*- from pythonds.basic.stack import Stack def parChecker(symb ...

  2. 判断括号匹配(nyoj2水)

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

  3. 括号匹配 区间DP (经典)

    描述给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起来 ...

  4. YTU 3003: 括号匹配(栈和队列)

    3003: 括号匹配(栈和队列) 时间限制: 1 Sec  内存限制: 128 MB 提交: 2  解决: 2 [提交][状态][讨论版] 题目描述 假设一个表达式中只允许包含三种括号:圆括号&quo ...

  5. 南阳理工ACM 括号匹配问题,并求出使得括号能够匹配需要新增的最小括号数(括号匹配(二))

    描述 给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起 ...

  6. 括号匹配问题(C++、堆栈)

    原文地址:http://www.cppblog.com/GUO/archive/2010/09/12/126483.html /* 括号匹配问题,比较经典,利用堆栈来实现(摘自internet) 1. ...

  7. 括号匹配(C++ Stack)

    最近在学习C++,所以使用stack容器来实现括号匹配 /**********************************************************/ stack<Ty ...

  8. java:数据结构(二)栈的应用(括号匹配)

    一.什么是括号匹配: 括号匹配就是利用计算机辨别表达式里面的括号是否书写成功 例如: {()((a)) }这就是一个正确 (()()   这就是一个错误的 二.括号匹配的算法: 众所周知,括号分为花括 ...

  9. NYOJ15|括号匹配(二)|区间DP|Elena

    括号匹配(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:6   描述 给你一个字符串,里面只包含"(",")","[&qu ...

随机推荐

  1. 剑指 Offer 15. 二进制中1的个数

    剑指 Offer 15. 二进制中1的个数 Offer 15 题目描述: 方法一:使用1逐位相与的方式来判断每位是否为1 /** * 方法一:使用1逐位与的方法 */ public class Off ...

  2. POJ-1797(最短路变形-dijkstra)

    Heavy Transportation POJ-1797 这题是最短路题型的变形,该题不是求起点到终点的最短路,而是求路径中的最小边的最大值. 这题的求解思路是:将原来dijkstra中的松弛方程改 ...

  3. 2.2 Python3基础-基本数据类型

    >>返回主目录 源代码 # 基本数据类型 # Number类型:如何查看变量的数据类型? name = 'Portos' print(type(name)) # 结果:str print( ...

  4. Windows下用户手册

      (1)net user(查看系统用户) (2)net user 用户名(查看具体某个系统用户详细信息) (3)net user 用户名 密码 /add(在本地组成员创建新用户,此时为Users组) ...

  5. 对话对话每日互动CEO方毅:数据智能应用的过去、现在和未来每日互动CEO方毅:数据智能应用的过去、现在和未来

    2008年,大数据的概念被首次提出,麦肯锡全球研究所给出的定义是:大数据是在一种获取.存储.管理.分析方面大大超出了传统数据库软件工具能力范围的数据集合. 2014年,"数据智能" ...

  6. 基于autofac的属性注入

    基于autofac的属性注入 什么是属性注入 在了解属性注入之前,要先了解一下DI(Dependency Injection),即依赖注入.在ASP.NET Core里自带了一个IOC容器,而且程序支 ...

  7. KVM虚拟化配置

    KVM虚拟化 虚拟化概念 KVM虚拟化概念详讲 虚拟化配置 首先开启虚拟化的支持 并且增加一个50g的硬盘 free查看内存 grep -Ei 'vmx|svm' /proc/cpuinfo查看虚拟机 ...

  8. Kubernetes使用metric-server让HPA弹性伸缩运行

    监控架构概述 kubernetes监控指标大体可以分为两类:核心监控指标和自定义指标,核心监控指标是kubernetes内置稳定可靠监控指标,早期由heapster完成,现由metric-server ...

  9. 全网最详细的新手入门Mysql命令和基础,小白必看!

    MySQL简介 什么是数据库 ? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是 ...

  10. 小白都能学会的Java注解与反射机制

    前言 Java注解和反射是很基础的Java知识了,为何还要讲它呢?因为我在面试应聘者的过程中,发现不少面试者很少使用过注解和反射,甚至有人只能说出@Override这一个注解.我建议大家还是尽量能在开 ...