POJ 3087【Shuffle'm Up】

13 篇文章 0 订阅
10 篇文章 0 订阅

思路:

  • 管什么颜色不颜色,就是串串。
  • 模拟题。
    1. (第一次)用 map,判断每次得到的串串是不是新串,如果不是就 continue,是则 break 输出 -1
    2. 因为每一个串只有一种产生方法,其左串和右串都是固定的,那么利用反证法,环路不可能突然成在中间,那样会导致某个串有两个不同的来源。因此,环路必然经过首串。所以,只需要判断每一次产生的串是否与第一次得到的串串相同即可。
  • 注意:
    1. 第一种代码中混用了 m.empty()m.clear(),找了好久好久。很生气。
    2. 第二种代码中第一次 while 不可以判断 reptemp

代码:

  • 法一:676K 0MS
//676K		0MS


#include <iostream>
#include <map>
#include <string>

using namespace std;

map<string , bool> book;
int n;
int ans;
string tar;

void init(){
	book.clear();
	ans = 0;
}

string com(string l , string r){
	string temp ;
	for(string::iterator il = l.begin() , ir = r.begin() ; il != l.end() ; il++ , ir++){
		temp += *ir;
		temp += *il;
	}
	ans++;
	return temp;
}

int main(){
	int T;cin>>T;
	for(int t=1;t<=T;t++){
		init();
		cin>>n;
		string l,r;
		string temp;
		
		cin>>l>>r;
		cin>>tar ;
		
		temp = com(l , r);//combine
		while(true){
			if(temp == tar)
				break;
			if(book[temp]){
				ans = -1;
				break;
			}
			book[temp] = true;
			l.clear() , r.clear();
			//l.empty(),r.empty();
			for(string::iterator i = temp.begin() ; i-temp.begin()!=n ; i++)
				l += *i;
			for(string::iterator i = temp.begin() + n ; i != temp.end() ; i++)
				r += *i;
			temp = com(l , r);
		}
		cout<<t<<' '<<ans<<endl;
	} 
	return 0;
}
  • 法二:676K 0MS
//676K		0MS


#include <iostream>
#include <string>

using namespace std;

int n;
int ans;
bool fir;
string tar;

void init(){
	ans = 0;
	fir = true;
}

string com(string l , string r){
	string temp ;
	for(string::iterator il = l.begin() , ir = r.begin() ; il != l.end() ; il++ , ir++){
		temp += *ir;
		temp += *il;
	}
	ans++;
	return temp;
}

int main(){
	int T;cin>>T;
	for(int t=1;t<=T;t++){
		init();
		cin>>n;
		string l,r;
		string temp;
		string rep ;//repeat
		
		cin>>l>>r;
		cin>>tar ;
		
		rep = temp = com(l , r);//combine
		while(true){
			if(temp == tar)
				break;
			if(!fir && temp == rep){
				ans = -1;
				break;
			}
			fir = false;
			l.clear() , r.clear();
			for(string::iterator i = temp.begin() ; i-temp.begin()!=n ; i++)
				l += *i;
			for(string::iterator i = temp.begin() + n ; i != temp.end() ; i++)
				r += *i;
			temp = com(l , r);
		}
		cout<<t<<' '<<ans<<endl;
	} 
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值