OpenJudge计算概论-单词排序
/*===================================== 单词排序 总时间限制:1000ms 内存限制: 65536kB 描述 输入一行单词序列,相邻单词之间由1个或多个空格间隔,请按照字母顺序输出这些单词(即按照字符串中字母的ASCII码排序,区分大小写,当首字母相同时,比较第2个字母,依次类推),要求重复的单词只输出一次。 输入 一行单词序列,最少1个单词,最多100个单词,每个单词长度不超过50,单词之间用至少1个空格间隔。 输出 按字母顺序输出这些单词,重复的单词只输出一次。 样例输入 She wants to go to Peking University to study Chinese 样例输出 Chinese Peking She University go study to wants 思路:
依次输入单词,用scanf函数即可。
每次输入一个单词后立即检查前面输入的所有单词当中是否含有该新出现的单词。若是没有则把它存到数组当中,否则忽略该新输入的单词。
输入所有单词后,对数组排序,排序时比较两个单词的方法用strcmp进行。
拍好序后输出所有单词即可。 ======================================*/
1 #include<stdio.h> 2 #include<string.h> 3 int main() 4 { 5 int i,k; 6 char a[100][50],temp[50]; 7 int n; 8 int flag,j; 9 freopen("5.in","r",stdin); 10 k=0;//表示现在为止已经往a数组放了k个单词 11 while(scanf("%s",temp)!=EOF) 12 { 13 flag=1;//flag==1表示a数组没含有刚输入的单词temp[] 14 for(i=0;i<k;i++)//检查a数组是否含有刚刚输入的单词temp[] 15 { 16 if(strcmp(a[i],temp)==0) 17 { 18 flag=0;//flag==0表示刚输入的单词temp[]已经包含在数组a里面 19 break; 20 } 21 } 22 if(flag==1) 23 { 24 strcpy(a[k],temp); 25 k++; 26 } 27 } 28 //下面是对数组a做选择排序 29 n=k; 30 for(i=0;i<n-1;i++) 31 { 32 k=i; 33 for(j=i+1;j<n;j++) //寻找a[i+1]~a[n-1]当中最小的元素并把它的下标记录到k里面。 34 if(strcmp(a[j],a[k])<0)//if(a[j] < a[k]) 35 k=j; 36 if(i!=k) 37 { 38 strcpy(temp,a[k]); 39 strcpy(a[k],a[i]); 40 strcpy(a[i],temp); 41 } 42 } 43 //下面输出排好序的a数组 44 for(i=0;i<n;i++) 45 { 46 printf("%s\n",a[i]); 47 } 48 return 0; 49 }
分类:
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