小白求学进阶

小白求学进阶,一个小白的奋斗过程

南阳理工ACM 题4《ASCII码排序》

4-ASCII码排序


内存限制:64MB 时间限制:3000ms Special Judge: No

accepted:76 submit:115

题目描述:

输入三个字符(可以重复)后,按各字符的ASCII码从小到大的顺序输出这三个字符。

输入描述:

第一行输入一个数N,表示有N组测试数据。后面的N行输入多组数据,每组输入数据都是占一行,有三个字符组成,之间无空格。

输出描述:

对于每组输入数据,输出一行,字符中间用一个空格分开。

样例输入:

复制
2
qwe
asd

样例输出:

e q w
a d s

题解:

    南阳理工换了个新的系统,感觉不错啊,哈哈哈哈哈,就是旧系统的数据迁移不过去,手动搬,看看哪些值得发的,就摆上来吧,看看以前写的代码,还是好好笑的哈哈哈哈哈哈。




原创代码:

 
#include<stdio.h>
#include<stdlib.h>
int main()
{
	char *p=0,ch;
	int i,n;
	scanf("%d",&n);
	getchar();
	p=(char *)calloc(n*3,sizeof(char));//吸收回车
	for(i=0;i<n*3;i=i+3)
	{
		*(p+i)=getchar();
		*(p+i+1)=getchar();
		*(p+i+2)=getchar();
		getchar();						//吸收回车键,三个数据为一组
		
	}
	for(i=0;i<n*3;i=i+3)
	{
		if(*(p+i)>*(p+i+1))				//3个if用来排序
		{
			ch=*(p+i);
			*(p+i)=*(p+i+1);
			*(p+i+1)=ch;
		}
		if(*(p+i)>*(p+i+2))
		{
			ch=*(p+i);
			*(p+i)=*(p+i+2);
			*(p+i+2)=ch;
		}
		if(*(p+i+1)>*(p+i+2))
		{
			ch=*(p+i+1);
			*(p+i+1)=*(p+i+2);
			*(p+i+2)=ch;
		}
		printf("%c %c %c\n",*(p+i),*(p+i+1),*(p+i+2));
	}
	free(p);
	return 0;
}        

阅读更多

扫码向博主提问

去开通我的Chat快问

weixin_40295575

非学,无以致疑;非问,无以广识
  • 擅长领域:
  • 二本学生
版权声明:博主最近都在,有不懂疑惑的,可以一起交流,也希望能有高人指点一二,谢啦!本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_40295575/article/details/80347253
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

南阳理工ACM 题4《ASCII码排序》

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭