This cheeseburger you don't need

题目连接:

http://acm.timus.ru/problem.aspx?space=1&num=1993

Description

Master Yoda is the oldest member of the Jedi Council. He conducts preparatory classes of little Younglings up to the moment they get a mentor. All Younglings adore master Yoda and they hope to grow as strong and wise as he is. Just like all little children, Younglings are absolutely hooked on new games and ideas. Now they decided to learn to speak just like master Yoda. Help the Younglings understand how Yoda would say this or that sentence.

Yoda is speaking the Galactic language using the specific word order — so-called "object-subject-verb".

Your program receives a sentence that interests the Younglings. They have already highlighted all important parts in the sentence. They use the curly {}-brackets for objects, round ()-brackets for subjects and square []-brackets for verbs.

A sentence in the input can be simple or complex. If the sentence is complex, then it consists of two simple sentences separated by a comma. Sometimes a comma is followed by a conjunction that is not in the brackets.

Each simple question has exactly one object, one subject and one verb. Your task is to simply put them in the correct order. Namely, first the object, then the subject, finally the verb. Also, please do not forget that only the first word in the whole sentence should begin with capital letter.

Input

The single line contains a sentence that interests the Younglings. The length of the sentence does not exceed 100 characters. All the words in the sentence consist of Latin letters. The first letter of the first word is capitalized and the rest are small. The sentence may contain a comma. Each simple sentence contains all three types of brackets. Each pair of brackets surrounds one or more words. No pair of brackets can surround the other bracket. Brackets are always located on the borders of words. The words in the sentence are separated by a single space. There is no space character before a comma or a closing bracket and also after an opening bracket. The conjunction (which can be only after a comma) is the only word that is not surrounded by a pair of brackets.

Output

Print the sentence with the word order Yoda would use. All brackets must be omitted. You should separate the words by a single space.

Sample Input

(We) [are] {blind}, if (we) [could not see] {creation of this clone army}

Sample Output

Blind we are, if creation of this clone army we could not see

Hint

题意

没括号的原样输出,有括号的就优先输出大括号,中括号,然后小括号这样

句首需要大写

题解:

模拟题,烦……

代码

#include <bits/stdc++.h>

using namespace std;

string base;
vector < string > str; string Clear_32(string s){
string res;
int Ed = s.size() - 1;
for( ; Ed >= 0 && s[Ed] == ' ' ; -- Ed);
for(int i = 0 ; i < s.size() ; ++ i){
if( s[i] != ' '){
for(int j = i ; j <= Ed ; ++ j) res.push_back( s[j] );
break;
}
}
return res;
} void Solve( string s , int INDEX ){
stack < int > sp;
string F[4];
int pos[4];
F[0]=F[1]=F[2]=F[3]="";
bool find = false;
for(int i = 0 ; i < s.size() ; ++ i){
if(s[i] == '[' || s[i] == '(' || s[i] == '{'){
sp.push( i );
if( find == false ) F[0]=s.substr(0,i);
find = true;
if(s[i] == '{') pos[1] = i;
else if(s[i] =='(') pos[2] = i;
else pos[3] = i;
}
else if(s[i] == ']' || s[i] == ')' || s[i] == '}'){
string * ptr = F;
int extra = 0;
if( s[i] == '}' ) extra = 1;
else if( s[i] == ')' ) extra=2;
else extra=3;
ptr += extra;
*ptr=s.substr(pos[extra]+1,i-pos[extra]-1);
}
}
for(int i = 1 ; i < 4 ; ++ i) F[i] = Clear_32( F[i] );
cout << F[0];
if(INDEX==0){
for(int i = 0 ; i < 4 ; ++ i)
if(F[i].size()){
if(F[i][0] <= 'z' && F[i][0] >='a'){
F[i][0] = F[i][0] - 'a' + 'A';
}
for(int j = 1 ; j < F[i].size() ; ++ j){
if(F[i][j] <= 'Z' && F[i][j] >= 'A'){
F[i][j] = F[i][j] - 'A' + 'a';
}
}
for(int k = i + 1 ; k < 4 ; ++ k){
for(int v = 0 ; v < F[k].size() ; ++ v){
if(F[k][v] <= 'Z' && F[k][v] >= 'A'){
F[k][v] = F[k][v] - 'A' + 'a';
}
}
}
break;
}
}
int isfirst = 0;
for(int i = 1 ; i < 4 ; ++ i){
if(F[i].size()){
if(isfirst==0) isfirst = 1;
else cout << " ";
cout << F[i];
}
}
} int main(int argc,char *argv[]){
// freopen("out.txt" , "w" , stdout );
getline(cin , base);
for(int i = 0 ; i < base.size() ; ++ i){
int j;
string temp;
for(j = i ; j < base.size() ; ++ j){
if( base[j] ==',' && i != j ) break;
temp.push_back( base[j] );
}
str.push_back( temp );
i = j - 1;
}
for(int i = 0 ; i < str.size() ; ++ i) Solve( str[i] , i );
cout << endl;
return 0;
}

URAL 1993 This cheeseburger you don't need 模拟题的更多相关文章

  1. ural 1993 This cheeseburger you don't need

    顺次存到{} [] () 遇到逗号就处理下,最后处理逗号之后的 #include <iostream> #include <cstring> #include <stri ...

  2. URAL 2046 A - The First Day at School 模拟题

    A - The First Day at SchoolTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudg ...

  3. ural 2032 Conspiracy Theory and Rebranding (数学水题)

    ural 2032  Conspiracy Theory and Rebranding 链接:http://acm.timus.ru/problem.aspx?space=1&num=2032 ...

  4. Ural 1209. 1, 10, 100, 1000... 一道有趣的题

    1209. 1, 10, 100, 1000... Time limit: 1.0 secondMemory limit: 64 MB Let's consider an infinite seque ...

  5. URAL 1519 Formula 1(插头DP,入门题)

    Description Background Regardless of the fact, that Vologda could not get rights to hold the Winter ...

  6. ural 2020 Traffic Jam in Flower Town(模拟)

    2020. Traffic Jam in Flower Town Time limit: 1.0 secondMemory limit: 64 MB Having returned from Sun ...

  7. ural 2015 Zhenya moves from the dormitory(模拟)

    2015. Zhenya moves from the dormitory Time limit: 1.0 secondMemory limit: 64 MB After moving from hi ...

  8. Ural 1079 - Maximum

    Consider the sequence of numbers ai, i = 0, 1, 2, …, which satisfies the following requirements: a0  ...

  9. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

随机推荐

  1. python中随机数生成

    1.random.random random.random()用于生成一个0到1的随机符小数: 0 <= n < 1.0 2.random.uniform random.uniform的函 ...

  2. BurpSuite 设置Hostname Resolution

    #写在前面 这种情况你可能遇到过: 对方用了CDN, 你查到了对方真实IP, 但还不能100%肯定. 这时候, 最好的测试就是 win/linux修改HOST文件 Win重启电脑 Linux重启网络 ...

  3. linux下route命令--说的比较清楚!

    linux下route命令     route命令感觉很不容易.一般开机后在命令行中使用route命令,会得到下面的信息   Kernel IP routing table   Destination ...

  4. iTextSharp之pdfRead(两个文件文本内容的比较,指定页数的pdf截取,水印的添加)

    using iTextSharp.text; using iTextSharp.text.pdf; using iTextSharp.text.pdf.parser; using System; us ...

  5. JS时间转换的一个坑位

    在做项目的时候,无意发现了一个小东西. new Date('2018-05-15') new Date('2018-5-15') 输出的结果是不同的,相差了8小时.然后让我回忆到之前看的一个时间转换函 ...

  6. 在ubuntu上安装Chrome

    1.下载谷歌浏览器源文件.链接有很多,以下是64位版本的下载地址 https://dl.google.com/linux/direct/google-chrome-stable_current_amd ...

  7. webservice使用

    soap方法 一:PHP本身的SOAP 所有的webservice都包括服务端(server)和客户端(client). 要使用php本身的soap首先要把该拓展安装好并且启用.下面看具体的code ...

  8. 查找网页元素对应的js代码

    按F12打开调试窗口,切换到Sources选项卡,最右边的Event Listener Breakpoints里勾选Mouse下的mouseover即可,当鼠标移动到图片上时触发mouseover事件 ...

  9. django时差8个小时问题

    问题现象: 在用django做好的网站,上传图片后显示的发布时间比当前时间差了8小时 查找问题: 查看服务器系统时间,经查与当前时间一致,无问题 查看数据库中的时间也一样 最终原因: 在setting ...

  10. csu 1550(字符串处理思路题)

    1550: Simple String Time Limit: 1 Sec  Memory Limit: 256 MBSubmit: 481  Solved: 211[Submit][Status][ ...