九度oj 1006 ZOJ问题 2010年浙江大学计算机及软件工程研究生机试真题
生活随笔
收集整理的這篇文章主要介紹了
九度oj 1006 ZOJ问题 2010年浙江大学计算机及软件工程研究生机试真题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目1006:ZOJ問題
時間限制:1 秒
內存限制:32 兆
特殊判題:否
提交:16244
解決:2742
題目描述:是否AC的規則如下: 1. zoj能AC; 2. 若字符串形式為xzojx,則也能AC,其中x可以是N個'o' 或者為空; 3. 若azbjc 能AC,則azbojac也能AC,其中a,b,c為N個'o'或者為空;
分析:
2種情況輸出"Accepted":
1."zoj"
2."xzo..ojx..x"(其中中間o的個數=末尾x的個數)
技巧:找到第一個'z'的位置和第一個'j'的位置,就可以就可以算出第一個'z'和第一個'j'之間的'o'的個數(就是末尾x的個數)
然后構造string s1="xzo..ojx..x"與原字符串比較
?
substr用法:s.substr(a,b)? 返回s[a]開始的(包括s[a])長b的字符串
http://baike.baidu.com/link?url=sNCZ2LsYgl82zQXh6xKA51dUV_sZRVh9tvrwDBMpqkzJ8IP6rv5JwVy8NNdY_5qZcRVOCQ3Z6GH8ZYNI7E5ctNnBkd_ZURxza5tLXzq9l8O
1 #include <cstdio> 2 #include<algorithm> 3 #include<iostream> 4 #include<string> 5 #include<cstring> 6 #include<vector> 7 using namespace std; 8 int main() 9 { 10 string s; 11 while(cin>>s){ 12 string x; 13 if(s=="zoj"){ 14 cout<<"Accepted"<<endl; 15 continue; 16 } 17 int i=0; 18 int tz=-1,tj=-1; 19 for(;i<s.length();i++){ 20 if(s[i]=='z'&&tz==-1){ 21 tz=i; 22 } 23 else{ 24 if(s[i]=='j'&&tj==-1){ 25 tj=i; 26 } 27 } 28 } 29 int num=tj-tz-1; 30 if(num>0){ 31 x=s.substr(0,tz); 32 /*for(i=0;i<tz;i++){ 33 if(s[i]!='o') 34 break; 35 } 36 if(i!=tz){ 37 cout<<"Wrong Answer"<<endl; 38 continue; 39 } 40 for(i=tz+1;i<tj;i++){ 41 if(s[i]!='o') 42 break; 43 } 44 if(i!=tj){ 45 cout<<"Wrong Answer"<<endl; 46 continue; 47 }*/ 48 string s1=x+'z'; 49 for(i=0;i<num;i++){ 50 s1+='o'; 51 } 52 s1+='j'; 53 for(i=0;i<num;i++){ 54 s1+=x; 55 } 56 if(s1==s){ 57 cout<<"Accepted"<<endl; 58 continue; 59 } 60 } 61 cout<<"Wrong Answer"<<endl; 62 } 63 return 0; 64 }?
轉載于:https://www.cnblogs.com/Deribs4/p/4291299.html
總結
以上是生活随笔為你收集整理的九度oj 1006 ZOJ问题 2010年浙江大学计算机及软件工程研究生机试真题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java雷达锁定
- 下一篇: Thread如何中断