Gym101889B. Buggy ICPC(打表)
比赛链接:传送门
题目:
- Problem B – Buggy ICPC
- Author
- : Gabriel Poesia, Brasil
- Alan Curing is a famous sports programmer. He is the creator of the theoretical model of computation
- known as the Alan Curing Machine (ACM). He’s most famous for creating his own computer for pro-
- gramming competitions: the Integrated Computer for Programming Contests (ICPC). This computer
- has a specialized operating system with commands for submitting code and testing executables on sam-
- ple inputs, an input generator, a wide display for debugging, and a very soft keyboard. However, as it
- happens even to the best, Alan’s creation has a nasty bug. Every time Alan types a vowel on the ICPC,
- the content of the current line is reversed.
- The bug has been extremely hard to track down, so Alan has decided to accept the challenge and
- use the computer as it is. He is currently training touch typing on the ICPC. For now, he is only typing
- strings using lowercase letters, and no spaces. When Alan types a consonant, it is appended to the end
- of the current line, as one would expect. When he types a vowel, however, the typed character is first
- added to the end of the line, but right after that the whole line is reversed. For example, if the current
- line has “imc” and Alan types “a” (a vowel), for a brief moment the line will become “imca”, but then the bug kicks in and turns the line into “acmi”. If after that he types the consonants “c”, “p” and “c”,in that order, the line becomes “acmicpc”.
- When practicing, Alan first thinks of the text he wants to type, and then tries to come up with asequence of characters he can type in order to obtain that text. He is having trouble, however, since he realized that he cannot obtain some texts at all (such as “ca”), and there are multiple ways of obtaining other texts (as “ac”, which is obtained whether he types “
- ac” or “ca”). Help Alan in his training by telling him in how many ways he can type each text he wishes to type. A way of typing a text T can
- be encoded by a string W with |T| characters such that if the characters are typed on the ICPC in the order they appear in W (i.e.W1, W2, . . . , W|
- T|) the final result is equal toT, considering ICPC’s known bug. Two ways are considered different if they are encoded by different strings. The ltters that trigger the bug in the ICPC when typed are “a”, “e”, “i”, “o” and “u”.
- Input
- The input consists of a single line that contains a non-empty string
- T
- of at most ^
- lowercase
- letters, representing the text Alan wants to type on the ICPC.
- Output
- Output a single line with an integer representing the number of distinct ways Alan can type the
- desired text
- T
- considering ICPC’s known bug.
- Sample input
- ac
- Sample output
- Sample input
- ca
- Sample output
- Sample input
- acmicpc
- Sample output
思路:
一上来就很容易想到用next_premutation枚举顺序暴力打表,于是就打了个表。。。猜了个结论。。。
面向结论证明应该还蛮容易的。。
打表代码:
- #include <bits/stdc++.h>
- using namespace std;
- const char vowel[] = {'a', 'e', 'i', 'o', 'u'};
- int main()
- {
- string s;
- vector <char> V;
- while (cin >> s) {
- V.clear();
- int cnt = ;
- for (int i = ; i < s.size(); i++) {
- V.push_back(s[i]);
- }
- sort(V.begin(), V.end());
- do {
- string tmp;
- for (int i = ; i < V.size(); i++) {
- tmp += V[i];
- for (int j = ; j < ; j++) {
- if (V[i] == vowel[j]) {
- reverse(tmp.begin(), tmp.end());
- break;
- }
- }
- }
- if (tmp == s) {
- for (int i = ; i < V.size(); i++) {
- cout << V[i];
- }
- cout << endl;
- cnt++;
- }
- }while (next_permutation(V.begin(), V.end()));
- cout << cnt << endl << endl;
- }
- return ;
- }
- /*
- ac
- ca
- acmicpc
- */
代码:
- #include <bits/stdc++.h>
- using namespace std;
- const char vowel[] = {'a', 'e', 'i', 'o', 'u'};
- const int MAX_N = 1e5 + ;
- int N;
- char T[MAX_N];
- int main()
- {
- scanf("%s", T);
- N = strlen(T);
- vector <int> ind;
- for (int i = ; i < N; i++)
- for (int j = ; j < ; j++) {
- if (T[i] == vowel[j]) {
- ind.push_back(i);
- break;
- }
- }
- int ans = ;
- int pos = -;
- if (ind.size() % ) {
- pos = ind.size()/;
- }
- else {
- pos = ind.size()/ - ;
- }
- if (pos+ < ind.size()) {
- ans = ind[pos+] - ind[pos];
- }
- if (ind.size() == ) {
- ans = N;
- }
- if (ind.size() == ) {
- ans = ;
- }
- else if (ind[] > ) {
- ans = ;
- }
- cout << ans << endl;
- return ;
- }
Gym101889B. Buggy ICPC(打表)的更多相关文章
- 2017-2018 ACM-ICPC Latin American Regional Programming Contest Solution
A - Arranging tiles 留坑. B - Buggy ICPC 题意:给出一个字符串,然后有两条规则,如果打出一个辅音字母,直接接在原字符串后面,如果打出一个元音字母,那么接在原来的字符 ...
- 2017-2018 ACM-ICPC Latin American Regional Programming Contest PART (11/13)
$$2017-2018\ ACM-ICPC\ Latin\ American\ Regional\ Programming\ Contest$$ \(A.Arranging\ tiles\) \(B. ...
- 2016 ACM/ICPC Asia Regional Qingdao Online 1001/HDU5878 打表二分
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- ACM/ICPC 之 暴力打表(求解欧拉回路)-编码(POJ1780)
///找到一个数字序列包含所有n位数(连续)一次且仅一次 ///暴力打表 ///Time:141Ms Memory:2260K #include<iostream> #include< ...
- ACM/ICPC 之 最短路-SPFA+正逆邻接表(POJ1511(ZOJ2008))
求单源最短路到其余各点,然后返回源点的总最短路长,以构造邻接表的方法不同分为两种解法. POJ1511(ZOJ2008)-Invitation Cards 改变构造邻接表的方法后,分为两种解法 解法一 ...
- ACM/ICPC 之 数据结构-邻接表+BFS(TSH OJ-无线广播Broadcast)
这道题中若能够构成互不干扰的区域,其构成的图其实就是汉密尔顿路(Hamilton road),因此如果能够观察出来可以直接转化为汉密尔顿路的存在性证明,即便不能观察,我相信ACMer也能转化为BFS问 ...
- ACM/ICPC 之 数据结构-邻接表+DP+队列+拓扑排序(TSH OJ-旅行商TSP)
做这道题感觉异常激动,因为在下第一次接触拓扑排序啊= =,而且看了看解释,猛然发现此题可以用DP优化,然后一次A掉所有样例,整个人激动坏了,哇咔咔咔咔咔咔咔~ 咔咔~哎呀,笑岔了- -|| 旅行商(T ...
- ACM/ICPC 之 数论-素数筛选法 与 "打表"思路(POJ 1595)
何为"打表"呢,说得简单点就是: 有时候与其重复运行同样的算法得出答案,还不如直接用算法把这组数据所有可能的答案都枚举出来存到一个足够大的容器中去-例如数组(打表),然后再输入数据 ...
- HDU 5878 I Count Two Three (打表+二分查找) -2016 ICPC 青岛赛区网络赛
题目链接 题意:给定一个数n,求大于n的第一个只包含2357四个因子的数(但是不能不包含其中任意一种),求这个数. 题解:打表+二分即可. #include <iostream> #inc ...
随机推荐
- Java实现简单的RPC框架
一.RPC简介 RPC,全称为Remote Procedure Call,即远程过程调用,它是一个计算机通信协议.它允许像调用本地服务一样调用远程服务.它可以有不同的实现方式.如RMI(远程方法调用) ...
- 关于Could not read pom.xml和No plugin found for prefix 'tomcate7' in the current project
当时出现的错误: 有大神知道我这个错误怎么解决吗[ERROR] No plugin found for prefix 'tomcate7' in the current project and in ...
- 【论文笔记】CBAM: Convolutional Block Attention Module
CBAM: Convolutional Block Attention Module 2018-09-14 21:52:42 Paper:http://openaccess.thecvf.com/co ...
- python基础知识点四
网络编程(socket) 软件开发的架构: 两个程序之间通讯的应用大致通过从用户层面可以分为两种: 1是C/S,即客户端与服务端,为应用类的,比如微信,网盘等需要安装桌面应用的 2是B/S,即浏览器与 ...
- Python打包项目为EXE程序
安装pyinstaller 如果使用了VirtualENV环境,则必须在要打包的项目环境中安装... 否则会找不到项目需求的包和模块 pip install -i https://pypi.douba ...
- 函数式语言简介(functional language)
1.什么是函数式语言? 是一种非冯·诺伊曼式的程序设计语言.函数式语言主要成分是原始函数.定义函数和函数型.这种语言具有较强的组织数据结构的能力,可以把某一数据结构(如数组)作为单一值处 ...
- 第 8 章 容器网络 - 062 - 如何使用 flannel host-gw backend?
flannel host-gw backend flannel 支持多种 backend:(1)vxlan backend:(2)host-gw: 与 vxlan 不同,host-gw 不会封装数据包 ...
- 开机自动启动WEB服务,共享目录。
最近工作中,需要共享一个目录,每次重启总要手动执行一下 nohup python -m SimpleHTTPServer 8000这个命令,想着实现让它开机自动启动,就一劳永逸了. 手动步骤如下: ...
- 【你不一定知晓的】C#取消异步操作
[你不一定知晓的]C#取消异步操作 在.Net和C#中运行异步代码相当简单,因为我们有时候需要取消正在进行的异步操作,通过本文,可以掌握 通过CancellationToken取消任务(包括non-c ...
- MyEclipse项目的BUG修复错误类型
一.The type java.lang.CharSequence cannot be resolved. It is indirectly referenced from required .cla ...