挑剔的小杜

Posted lytwajue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了挑剔的小杜相关的知识,希望对你有一定的参考价值。

挑剔的小杜

时间限制:1000 ms  |  内存限制:65535 KB

难度:2

描写叙述

小杜一直都不喜欢数学,可是他特爱语文,所以对英语也很感兴趣。所以他也就有个习惯,一看到字母里面插有数字,一定要把他所有划去。

如今给你纸,纸上有非常多既含有字母,又含有数字的句子(还包含一些标点符号)。你须要将数字找出来放在一边,并组成一个最大的数。然后逆序输出全部字母。和那个最大的数。

输入

第一行:N表示有多少组数据。


接下来的N行。每行有一句话。长度不超过1000

输出

每句话相应输出两行。
第一行输出字母的总个数及其全部的字母(按原来输入的相反的顺序输出),中间须要一个空格分开。


第二行输出那个数字的总个数及最大的数,中间须要一个空格分开。


(假设没有字母或数字,则相应仅仅须要输出一个0

例子输入

2

abcabc123abc.

aaa

例子输出

9 cbacbacba

3 321

3 aaa

0


代码1:

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int com(const void *a,const void *b)
{
	return *(int *)a-*(int *)b;
}
int main(void)
{
	int n;
	scanf("%d",&n);
	while(n--)
	{
		char str[1000],ch[1000];
	    int  num[1000];
		int count1=0,count2=0;
		scanf("%s",str);
		int j=0,k=0;
		for(int i=0;i<strlen(str);i++)
		{
			if(str[i]>='0'&&str[i]<='9')
			{
				num[j++]=str[i]-'0';
				count1++;
			}
			if(str[i]>='a'&&str[i]<='z')
			{
				ch[k++]=str[i];
				count2++;
			}
		}
		num[j]='\0';
		ch[k]='\0';
		qsort(num,count1,sizeof(num[0]),com);
		if(count2!=0)
		{
			printf("%d ",count2);
			for(int j=count2-1;j>=0;j--)
			{
				printf("%c",ch[j]);
			}
			printf("\n");
		}
		else
		{
			printf("0\n");
		}
		if(count1!=0)
		{
			printf("%d ",count1);
			for(int j=count1-1;j>=0;j--)
			{
				printf("%d",num[j]);
			}
			printf("\n"); 
		}
		else
		{
			printf("0\n");
		}
	}	
	return 0;
} 

代码2:

#include<stdio.h>
int num[1003];
char str[1003];
int main()
{
	int n=0,k=0,t=0,i,j,a,b=1;
	char ch;
	scanf("%d",&n);
	getchar();
	while(n--)
	{
		for(i=0;i<=1003;i++)
			num[i]=0;
		j=0;
		i=0;
		while((ch=getchar())!='\n')
		{
			if(ch>='0'&&ch<='9')
			{
				num[i++]=ch-'0';
			}
			if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z'))
			{
				str[j++]=ch;
			}
		}
		str[j]='\0';   
		for(k=1;k<i;k++)
		{
			for(a=0;a<i-k;a++)
			{
				if(num[a]<num[a+1])
				{
					t=num[a];
					num[a]=num[a+1];
					num[a+1]=t;
				}
			}
		}
		printf("%d ",j);
		for(k=j-1;k>=0;k--)
			printf("%c",str[k]);
		printf("\n%d ",i);
		for(k=0;k<i;k++)
			printf("%d",num[k]);
		printf("\n");
	}
}


以上是关于挑剔的小杜的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ 1691 usaco2007 挑剔的美食家

1691: [Usaco2007 Dec]挑剔的美食家

[BZOJ1691][Usaco2007 Dec]挑剔的美食家

为啥 Swift 的三元运算符对空格如此挑剔?

BZOJ_1691_[Usaco2007 Dec]挑剔的美食家_贪心

BZOJ 1691: [Usaco2007 Dec]挑剔的美食家 [treap 贪心]