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 }
复制代码

 

posted on   华山青竹  阅读(2540)  评论(0编辑  收藏  举报

编辑推荐:
· .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

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示