hdu 4550

每取一个数字尽量把小数字往左放,当遇到0时要在后面的卡片找不大于首位的卡片,

如果找到,就把0放到左边(标记该卡片的位置),否则放右边,

注意:第一个数字可能就为0.









#include<stdio.h>
#include<string.h>
char s[110],str[210];
int main()
{
	int i,j,n,k,t,len;
	char *p,*q,ch,ph;
	scanf("%d",&t);
	while(t--)
	{
		scanf("%s",s);
		len=strlen(s);
		str[101]=s[0];
		p=q=&str[101];
		ch=p[0];
		k=0;//比首位非0数字小的数字最靠后的位置
		if(ch=='0')//如果第一个数为0,找非0的数字
		{
			ph='9';
			for(j=1;j<len;j++)
				if(s[j]<=ph&&s[j]!='0')
				{k=j;ph=s[j];}
			if(k==0)//如果没有,结果为0;
			{printf("0\n");continue;}
		}
		for(i=1;s[i];i++)
		{
			if(i==k)//遇到被被标记的数字必须放首位
			{
				p--;p[0]=s[k];
				ch=p[0];
				k=0;continue;
			}
			if(s[i]!='0')//非0数字跟首位比较
			{
				if(s[i]<=p[0])//如果小于首位,则更新首位
				{
					p--;p[0]=s[i];
					ch=p[0];
				}
				else {q++;q[0]=s[i];}//加入末位
			}
			else //找有没有比最靠前的非0数字小的数字
			{		
				ph=ch;
				for(j=i+1;j<len;j++)
					if(s[j]<=ph&&s[j]!='0')
					{k=j;ph=s[j];}
				if(k==0)
				{q++;q[0]=s[i];}//没有,0加入末位
				else 
				{p--;p[0]=s[i];}//找到就加入首位
			}
		}
		q++;q[0]=0;
		printf("%s\n",p);
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值