POJ 3087 Shuffle'm Up 模拟,看着不像…
2018-06-17 23:53:55来源:未知 阅读 ()
题意:给定s1,s1两副扑克,顺序从下到上。依次将s2,s1的扑克一张一张混合。例如s1,ABC; s2,DEF. 则第一次混合后为DAEBFC. 然后令前半段为s1, 后半段为s2. 如果可以变换成所给出的字符串,输出变换次数即可;否则,输出-1。
这题数据太水了,我是这样判断无法变换成题目所给出的字符串的:将每一次变换后的字符串存进数组,每次变换后由于之前变换后的字符串相比较,如果有相同的,就说明会无限循环下去。这样一来,循环次数会增加很多,然而0ms过了。。。
#include <iostream> #include <cstdio> #include <cstring> using namespace std; char ss[1000][200]; int main() { //freopen("in.txt","r",stdin); int n; scanf("%d",&n); int t=1; while(n--) { int m; bool flag=false; char s1[200],s2[200],s[400]; memset(s1,0,sizeof(s1)); memset(s2,0,sizeof(s2)); memset(s,0,sizeof(s)); memset(ss,0,sizeof(ss)); scanf("%d%s%s%s",&m,s1,s2,s); for(int i=0;; i++) { for(int j=0; j<m; j++) ss[i][2*j]=s2[j]; for(int j=0; j<m; j++) ss[i][2*j+1]=s1[j]; if(strcmp(s,ss[i])==0) { printf("%d %d\n",t,i+1); break; } else { for(int j=0; j<i; j++) if(strcmp(ss[i],ss[j])==0) { printf("%d -1\n",t); flag=true; break; } if(flag) break; } for(int j=0; j<m; j++) { s1[j]=ss[i][j]; s2[j]=ss[i][j+m]; } } t++; } return 0; }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- POJ-3278 2020-04-01
- Asteroids!_poj2225 2020-02-09
- poj-1753题题解思路 2020-01-26
- POJ1852 2019-11-11
- POJ2431 优先队列+贪心 - biaobiao88 2019-11-03
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash