本题要求编写程序,读入5个字符串,按由小到大的顺序输出。
输入格式:
输入为由空格分隔的5个非空字符串,每个字符串不包括空格、制表符、换行符等空白字符,长度小于80。
输出格式:
按照以下格式输出排序后的结果:
After sorted:
每行一个字符串
输入样例:
red yellow blue green white
输出样例:
After sorted:
blue
green
red
white
yellow
此题有两个重点:
- 如何存放这5个字符串?
- 如何比较各个字符串的大小?
对于第一个问题有两种办法:一种是定义5个一位字符数组,分别用scanf函数对其进行输入,因为scanf函数无法录入空格、制表符和换行符,所以能达到题目的输入要求;第二种办法则是用一个二维数组存放这5个字符串,每行存放一个字符串,但注意每行的字符串只包含有效字符不包含字符串结束符’\0’,每个字符串之间用空格分离。
第二种办法相比第一种办法好处在于不需要定义5个字符串然后逐个录入字符,但缺点在于需要使用多个for循环遍历来得到结果,同时也需要在每行输入字符串的同时检测是否有空格、制表符和换行符输入。
对于第二个问题目前我唯一知道的解决办法就是使用strcmp函数来比较各个字符串大小,但在此基础上可以简化这一过程,直接比较每个字符串的首字符大小,但仅限于各个字符串首字符都不相同的情况下,此处用这种方法只是为了拓展一下思路,毕竟现实生活中很少会需要比较字符串的大小,因此只对最基本的情况做出相应对策,更稳妥的办法还是用strcmp函数搭配任一种排序方法来做。
方法一:
#include <stdio.h>
#include<string.h>
int main(void){
char a[80],b[80],c[80],d[80],e[80],f[5],temp;
int i,j;
scanf("%s%s%s%s%s",a,b,c,d,e);
f[0]=a[0];f[1]=b