Tournament Chart

传送门:链接  来源:UPC10889

题目描述

In 21XX, an annual programming contest, Japan Algorithmist GrandPrix (JAG) has become one of the most popular mind sports events.

JAG is conducted as a knockout tournament. This year, N contestants will compete in JAG. A tournament chart is represented as a string. '[[a-b]-[c-d]]' is an easy example. In this case, there are 4 contestants named a, b, c, and d, and all matches are described as follows:

Match 1 is the match between a and b.

Match 2 is the match between c and d.

Match 3 is the match between [the winner of match 1] and [the winner of match 2].

More precisely, the tournament chart satisfies the following BNF:

<winner> ::= <person> | "[" <winner> "-" <winner> "]"

<person> ::= "a" | "b" | "c" | ... | "z"

You, the chairperson of JAG, are planning to announce the results of this year's JAG competition. However, you made a mistake and lost the results of all the matches. Fortunately, you found the tournament chart that was printed before all of the matches of the tournament. Of course, it does not contains results at all. Therefore, you asked every contestant for the number of wins in the tournament, and got N pieces of information in the form of "The contestant ai won vi times".

Now, your job is to determine whether all of these replies can be true.

输入

The input consists of a single test case in the format below.

S

a1 v1

:

aN vN

S represents the tournament chart. S satisfies the above BNF. The following N lines represent the information of the number of wins. The (i+1)-th line consists of a lowercase letter ai and a non-negative integer vi (vi≤26) separated by a space, and this means that the contestant ai won vi times. Note that N (2≤N≤26) means that the number of contestants and it can be identified by string S. You can assume that each letter ai is distinct. It is guaranteed that S contains each ai exactly once and doesn't contain any other lowercase letters.

输出

Print 'Yes' in one line if replies are all valid for the tournament chart. Otherwise, print 'No' in one line.

样例输入

[[m-y]-[a-o]]
o 0
a 1
y 2
m 0

样例输出

Yes

题目大意:

给出上面的BNF公式(看不懂),猜测应该是一个公式类似: [ [a-b]-c ] (这个比样例有普遍性)

每个 - 代表前面的队伍要和后面的队伍比赛,获胜的再与后面的比,在上面的例子中,是a先与b比赛,获胜者再与c比。

题目给出每个队伍最终的获胜次数,让你判断这个数据有没有可能是正确的。

解题思路:

按照下图一步步模拟就行了,因为要用到删除操作,直接用string不太好实现,可以用 vector<char>,这篇博很详细:传送门 。

具体实现就是每次遍历vector,找到两边都是字母的减号,删除【vc[i-2],vc[i+2]】的内容,再把胜场多的字符插入进去(也可以先修改字符再删内容,只是区间要变化一下),并将他对应的胜场-1(map数组在这很好用)。

判断条件:

两个比赛队伍,肯定会有一个会输,也就是胜场为0,否则就输出NO。

如果两个比赛的队伍胜场相同,也要输出NO。

最后只剩下的一个队伍对应的胜场应该也是0,否则输出NO。

AC代码:

感谢队友给找的bug:https://me.csdn.net/qq_43559193

#include<bits/stdc++.h>
using namespace std;
int main()
{
string a;
cin>>a; ///输入字符串
int la=a.size(),cnt=0;
for(int i=0;i<la;i++){
if(a[i]>='a'&&a[i]<='z'){
cnt++;
}
}
vector<char>vc;
for(int i=0;i<la;i++){ ///字符串内容赋值到vector中(输入的时候直接往里面存也可以)
vc.push_back(a[i]);
}
map<char,int>mp;
for(int i=0;i<cnt;i++){ ///输入胜场,存入mp数组
int num;
char id;
cin>>id>>num;
mp[id]=num;
}
while(vc.size()!=1){
for(int i=0;i<vc.size();i++){
if(vc[i]=='-'&&vc[i-1]>='a'&&vc[i-1]<='z'&&vc[i+1]>='a'&&vc[i+1]<='z'){
if(!(mp[vc[i+1]]==0||mp[vc[i-1]]==0)||(mp[vc[i+1]]==mp[vc[i-1]])){
cout<<"No"<<endl; ///一定要判断,不然会死循环
return 0;
}
if(mp[vc[i+1]]>mp[vc[i-1]]){ ///减号右边的胜场多
vc[i+2]=vc[i+1];///先修改值
mp[vc[i+1]]--;
vc.erase(vc.begin()+i-2,vc.begin()+i+2); ///删除区间内容
break;
}else if(mp[vc[i+1]]<mp[vc[i-1]]){///减号左边的胜场多
vc[i+2]=vc[i-1];
mp[vc[i-1]]--;
vc.erase(vc.begin()+i-2,vc.begin()+i+2);
break;
}
}
}
}
if(mp[vc[0]]==0) cout<<"Yes"<<endl;
else cout<<"No"<<endl;
return 0;
}

Tournament Chart【模拟+vector+map+string】的更多相关文章

  1. programming review (c++): (1)vector, linked list, stack, queue, map, string, bit manipulation

    编程题常用知识点的review. most important: 想好(1)详尽步骤(2)边界特例,再开始写代码. I.vector #include <iostream> //0.头文件 ...

  2. POJ 3096 Surprising Strings(STL map string set vector)

    题目:http://poj.org/problem?id=3096 题意:给定一个字符串S,从中找出所有有两个字符组成的子串,每当组成子串的字符之间隔着n字符时,如果没有相同的子串出现,则输出 &qu ...

  3. 2015-2016 ACM-ICPC, NEERC, Southern Subregional Contest A Email Aliases(模拟STL vector+map)

    Email AliasesCrawling in process... Crawling failed Time Limit:2000MS     Memory Limit:524288KB     ...

  4. POJ 3087 Shuffle'm Up【模拟/map/string】

    Shuffle'm Up Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14471 Accepted: 6633 Descrip ...

  5. PAT 1039 Course List for Student (25分) 使用map<string, vector<int>>

    题目 Zhejiang University has 40000 students and provides 2500 courses. Now given the student name list ...

  6. c++ list, vector, map, set 区别与用法比较

    http://blog.csdn.net/alex_xhl/article/details/37692297 List封装了链表,Vector封装了数组, list和vector得最主要的区别在于ve ...

  7. UVA 156:Ananagrams (vector+map+sort)

    题意:一大堆单词中间有空格隔开,以'#'结束输出,问只出现一次的的单词有哪些(如果两个具有相同的长度,相同的字母也算是相同的,不区分大小写,如:noel和lone属于一个单词出现两次).最后按照字典序 ...

  8. list, vector, map, set 区别与用法比较

    List封装了链表,Vector封装了数组, list和vector得最主要的区别在于vector使用连续内存存储的,他支持[]运算符,而list是以链表形式实现的,不支持[]. Vector对于随机 ...

  9. 【数据结构】Tournament Chart

    Tournament Chart 题目描述 In 21XX, an annual programming contest, Japan Algorithmist GrandPrix (JAG) has ...

随机推荐

  1. PAT-1080 Graduate Admission (结构体排序)

    1080. Graduate Admission It is said that in 2013, there were about 100 graduate schools ready to pro ...

  2. web项目——javax.servlet.ServletException: Circular view path [registerForm]

    报错: 控制台输出: 三月 21, 2019 10:12:32 上午 org.springframework.web.servlet.PageNotFound noHandlerFound 警告: N ...

  3. 去掉shiro登录时url里的JSESSIONID https://blog.csdn.net/aofavx/article/details/51701012

    经过查找论坛和分析源码,确认了是在ShiroHttpServletResponse里加上的. 因此继承ShiroHttpServletResponse类,覆盖相应方法,再重写 ShiroFilterF ...

  4. js数组取出非重复元素

    接地气,兼容性好,支持IE8) function diff(arr1,arr2){ var a = []; var b = []; for(var i=0;i<arr2.length;i++){ ...

  5. SQL SERVER修改为sa登陆权限报错,233,18456接连出现【抓狂ing】

    [记录生活] 今天做作业需要修改sa权限,本人电脑没错误. 同样教程发给朋友,错误百出.... 话不多说,百度很多解决方法,但是都没有解决,贴出解决方法. 0.用Windows身份验证登录,执行SQL ...

  6. 【Mathtype】安装Mathtype后,word无法粘贴的问题

    Win10安装mathtype后,word工具栏中自动添加mathtype的选项(mathtype为了使用户更加方便使用,故自动添加),但是却导致word无法粘贴.如何解决该问题? [方案1]官网描述 ...

  7. MVC设计模式-查询与删除

    MVC是Model-View-Controller的简称,即模型-视图-控制器.MVC是一种设计模式,它把应用程序分成三个核心模块: 模型:模型是应用程序的主体部分,模型表示业务数据和业务逻辑. 一个 ...

  8. 【LINQ标准查询操作符总结】之聚合操符

    C#  中的LINQ 提供了两种操作方式,查询表达式和查询操作符,所有的查询表达式都有对应的查操作符类替代,查询表达式有点“类” SQL,在代码中写SQL,总觉得不够“优雅”,使用查询操作符就显得“优 ...

  9. 如何开启远程桌面连接功能?windows的远程桌面连接功能使用步骤

    由于远程桌面的诞生,为电脑工作者提供了极大的便利.首先,推荐1款比较适合服务器管理的远程桌面: 可以管理1000+服务器/vps的远程桌面:IIS7远程桌面管理 开启远程桌面功能步骤: 1.右键点击电 ...

  10. Java实现 蓝桥杯 算法提高 快乐司机

    算法提高 快乐司机 时间限制:1.0s 内存限制:256.0MB 问题描述 "嘟嘟嘟嘟嘟嘟 喇叭响 我是汽车小司机 我是小司机 我为祖国运输忙 运输忙" 这是儿歌"快乐的 ...