卡片游戏
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total Submission(s): 1665 Accepted Submission(s): 485
Problem Description
小明最近宅在家里无聊,于是他发明了一种有趣的游戏,游戏道具是N张叠在一起的卡片,每张卡片上都有一个数字,数字的范围是0~9,游戏规则如下:
首先取最上方的卡片放到桌子上,然后每次取最上方的卡片,放到桌子上已有卡片序列的最右边或者最左边。当N张卡片全部都放到桌子上后,桌子上的N张卡片构成了一个数。这个数不能有前导0,也就是说最左边的卡片上的数字不能是0。游戏的目标是使这个数最小。
现在你的任务是帮小明写段程序,求出这个最小数。
首先取最上方的卡片放到桌子上,然后每次取最上方的卡片,放到桌子上已有卡片序列的最右边或者最左边。当N张卡片全部都放到桌子上后,桌子上的N张卡片构成了一个数。这个数不能有前导0,也就是说最左边的卡片上的数字不能是0。游戏的目标是使这个数最小。
现在你的任务是帮小明写段程序,求出这个最小数。
Input
第一行是一个数T,表示有T组测试数据;
然后下面有T行, 每行是一个只含有0~9的字符串,表示N张叠在一起的卡片,最左边的数字表示最上方的卡片。
[Technical Specification]
T<=1000
1 <= N <= 100
然后下面有T行, 每行是一个只含有0~9的字符串,表示N张叠在一起的卡片,最左边的数字表示最上方的卡片。
[Technical Specification]
T<=1000
1 <= N <= 100
Output
对于每组测试数据,请在一行内输出能得到的最小数。
Sample Input
3 565 9876543210 9876105432
Sample Output
556 1234567890 1678905432
Source
/*
1
011110122
好贱的测试数据
*/
#include <cstdio>
#include <iostream>
using namespace std;
int slen;
string s;
inline int find(int a,char now){
int i,flag=-1;
int small=99999999;
char f='0';
for(i=a+1;i<slen;i++){
if(s[i]=='0')
continue;
if(s[i]-'0'<=small) //注意这里如果相同,选择靠后面的
{
small=s[i]-'0';
f=s[i];
flag=i;
}
}
if(f<=now)
return flag;
else
return -1;
}
int main(){
int t,i,len,j;
string re;
cin>>t;
while(t--){
cin>>s;
re="";
len=0;
slen=s.length();
for(i=0;i<slen;i++){
if(s[i]=='0'){
int he;
if(re.length()==0)
he=find(i,'9');
else
he=find(i,re[0]);
if(he==-1)
re=re+s[i];
else{
re=s[i++]+re;
for(;i<he;i++) {
if(s[i]!='0')
re=re+s[i] ;
else
re=s[i]+re;
}
re=s[i]+re;
for(++i;i<slen;i++)
re=re+s[i];
}
} else{
if(s[i]==re[0]){
for(j=0;re[j]!='\0';j++){
if(re[j]<s[i])
{
re=re+s[i];
break;
}
else if(re[j]>s[i])
{
re=s[i]+re;
break;
}
}
if(re[j]=='\0')
re=re+s[i];
}
else if(s[i]<re[0]){
re=s[i]+re;
}else{
re=re+s[i];
}
}
}
cout<<re<<endl;
}
return 0;
}
/*
1
011110122
好贱的测试数据
*/
/*
#include <cstdio>
#include <iostream>
using namespace std;
int slen;
string s;
inline int find(int a,char now){
//0放不放前面的条件是到结尾有没比当前首字符小的 ,找到个最小的,
// 然后把途中非0的丢后面,0丢前面
int i,flag=-1; //标记位置
int small=99999999; //标记最小的
char f='0';
for(i=a+1;i<slen;i++){
if(s[i]=='0')
continue;
if(s[i]-'0'<=small) //注意这里如果相同,选择靠后面的
{
small=s[i]-'0';
f=s[i];
flag=i;
}
}
if(f<=now) //0放前
return flag;
else
return -1;
//返回应放在0前面的下标
}
int main(){
int t,i,len,j;
string re;
cin>>t;
while(t--){
cin>>s;
re="";
len=0;
slen=s.length();
for(i=0;i<slen;i++){
//是0
if(s[i]=='0'){
int he;
if(re.length()==0)
he=find(i,'9');
else
he=find(i,re[0]);
if(he==-1) //放尾巴
re=re+s[i];
else{
re=s[i++]+re; //0放前
for(;i<he;i++) {
//遍历到标志位置前非0都放后
if(s[i]!='0')
re=re+s[i] ;
else
re=s[i]+re;
}
//把标记位置放前
re=s[i]+re;
for(++i;i<slen;i++)
re=re+s[i];
}
} else{
//判断是否和首字符相同
if(s[i]==re[0]){
for(j=0;re[j]!='\0';j++){
if(re[j]<s[i])
{
re=re+s[i];
break;
}
else if(re[j]>s[i])
{
re=s[i]+re;
break;
}
}
if(re[j]=='\0')
re=re+s[i];
}
else if(s[i]<re[0]){
//比首字符小
re=s[i]+re;
}else{
//比首字符大
re=re+s[i];
}
}
}
cout<<re<<endl;
}
return 0;
}
*/