OpenJudge计算概论-字符串排序

简介: /*====================================================================== 字符串排序 总时间限制: 1000ms 内存限制: 65536kB 描述 参考整数排序方法,设计一种为字符串排序的算法,将字符串从小到大输出 输入 第一行为测试数据组数t, 后面跟着t组数据。
/*======================================================================
字符串排序
总时间限制: 1000ms 内存限制: 65536kB
描述
参考整数排序方法,设计一种为字符串排序的算法,将字符串从小到大输出
输入
第一行为测试数据组数t, 后面跟着t组数据。每组数据第一行是n,表示这组数据有n行字符串,接下来是要排序的n行字符串。每行字符串的字符个数不会大于200, n < 100。
输出
对于每组数据,输出排好序的字符串,每组输出后要多输出一个空行
样例输入
2
2
Hello
World
4
I
Love
C
Language!
样例输出
Hello
World

C
I
Language!
Love


思路:
对t组数据的每一组,可以输入整组数据到二维的char数组(注意:二维的char数组的a[i]相当于第i行的首地址,所以可以gets(a[i]))
输入一组数据后对其排序,可以考虑用任何一种排序,下面代码使用选择排序。 ========================================================================
*/
 1 #include<stdio.h>
 2 #include<string.h>
 3 int main()
 4 {
 5     int t,n;
 6     int k,i,j,m;
 7     char a[101][201],temp[201];
 8     freopen("5.in","r",stdin);
 9     //freopen("result.out","w",stdout);
10     scanf("%d",&t);
11     for(k=0;k<t;k++)
12     {
13         scanf("%d",&n);
14         getchar();//接收上一行scanf的回车符 
15         for(i=0;i<n;i++)
16             gets(a[i]);//scanf("%s",a[i]);无法接收含有空格的字符串,所以这个题用scanf会Wrong Answer。 
17         //下面是选择排序
18         for(i=0;i<n-1;i++)
19         {
20             m=i;
21             for(j=i+1;j<n;j++)
22             {
23                 if(strcmp(a[j],a[m])<0)
24                 {
25                     m=j;
26                 }
27             }
28             if(i!=m)//这里交换两行字符串
29             {
30                 strcpy(temp,a[i]);
31                 strcpy(a[i],a[m]);
32                 strcpy(a[m],temp);
33             }
34         }
35         //下面输出结果
36         for(i=0;i<n;i++)
37             printf("%s\n",a[i]);
38         if(k!=t-1) printf("\n");/**/
39     }
40     return 0;
41 }

 

相关文章
|
机器学习/深度学习 人工智能 算法
【算法基础】分解质因数
【算法基础】分解质因数
161 0
|
8月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1 算法训练 区间k大数查询
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1 算法训练 区间k大数查询
51 0
|
8月前
|
存储 机器学习/深度学习 人工智能
【算法基础】基础算法(三)--(双指针算法、位运算、离散化、区间合并)
【算法基础】基础算法(三)--(双指针算法、位运算、离散化、区间合并)
|
8月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-150 6-1 递归求二项式系数值
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-150 6-1 递归求二项式系数值
71 1
|
8月前
|
C语言
c语言编程练习题: 7-11 计算平均分
已知某位学生的数学、英语和计算机课程的成绩分别是87分、72分和93分,求该生3门课程的平均成绩(结果按整型输出)
107 0
|
8月前
|
搜索推荐 大数据 C++
C++系列案例-大数据减法-绘制余弦曲线-兔子数量-快速排序
C++系列案例-大数据减法-绘制余弦曲线-兔子数量-快速排序
《蓝桥杯每日一题》差分·Acwing3729. 改变数组元素
《蓝桥杯每日一题》差分·Acwing3729. 改变数组元素
60 0
《蓝桥杯每日一题》差分·Acwing3729. 改变数组元素
JAVA实现开根号的两种方式:二分法以及牛顿迭代法
JAVA实现开根号的两种方式:二分法以及牛顿迭代法
295 0
|
算法
基础算法(大数操作 前缀和 差分)
基础算法(大数操作 前缀和 差分)
79 0
数论整理之特殊数one:斐波那契数列
数论整理之特殊数one:斐波那契数列
104 0