OpenJudge计算概论-字符串排序
/*====================================================================== 字符串排序 总时间限制: 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 }
分类:
005-字符串
, OJ-OpenJudge
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App