6-5 输入单词并排序输出 (20 分)

前言

记录PAT题目

一、题目

本题要求通过input()函数实现输入若干个单词(每单词的长度不超过20,单词的最大数目不超过10)。输入过程中遇到单词END 则提前结束输入(END不作为后面排序的单词),或单词数目达到10个也结束。然后调用函数paixu(),对这若干个单词按字典顺序进行排序,最后调用函数printArr()输出排序后的单词,输出的单词之间以空格进行分隔,最后一个单词后面没有空格。

函数接口定义:
int input(char ar2[][21]);
其中函数的返回值等于输入的有效单词的数目。
void paixu(char ar2[][21], int n);
其中函数完成对ar2数组中的n个字符串进行排序。
void printArr(char ar2[][21], int n);
其中函数完成对ar2数组中的n个字符串进行输出。
裁判测试程序样例:
#include<stdio.h>
#include<string.h>
int input(char ar2[][21]);
void paixu(char ar2[][21], int n);
void printArr(char ar2[][21], int n);
int main(void)
{
char arr[10][21]={0};
int n;
n=input(arr);
paixu(arr,n);
printArr(arr,n);

return 0;

}
/* 请在这里填写答案 */
输入样例:
China Britain America Japan Egypt END
结尾无空行

输出样例:
After sorted:
America Britain China Egypt Japan
结尾无空行

输入样例:
END
结尾无空行

输出样例:
NO WORD
结尾无空行

输入样例:
a1 b2 c3 d4 e5 a6 b7 c8 d9 e10 a11 b12 c13
结尾无空行

输出样例:
After sorted:
a1 a6 b2 b7 c3 c8 d4 d9 e10 e5
结尾无空行

二、答案

int input(char ar2[][21])               // 其中函数的返回值等于输入的有效单词的数目。
{
    int cnt = 0,i;
    
    for(i=0;i<10;i++)
    {
        scanf("%s",&ar2[i]);
        if( strcmp(ar2[i],"*END*")==0 )
            return i;
    }
    
    return i; // 实际长度
}


void paixu(char ar2[][21], int n)      // 其中函数完成对ar2数组中的n个字符串进行排序。
{
    for(int i=0;i<n-1;i++)
    {
        for(int j=0;j<n-i-1;j++)
        {
            if( strcmp(ar2[j],ar2[j+1]) >0 )
            {
                char temp[21];
                strcpy(temp,ar2[j]);
                strcpy(ar2[j],ar2[j+1]);
                strcpy(ar2[j+1],temp);
            }
        }
    }

}

void printArr(char ar2[][21], int n)   // 其中函数完成对ar2数组中的n个字符串进行输出。
{
    if(n==0)
    {
        printf("NO WORD");
    }
    else
    {
        printf("After sorted:\n");
        for(int i=0;i<=n;i++)
        {
            printf("%s%c",ar2[i],i+1==n?'\0':' ');
        }
    }

}
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的C语言程序,用于对从键盘输入的7-11英文单词进行排序: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_WORDS 11 #define MAX_WORD_LENGTH 20 int main(void) { char words[MAX_WORDS][MAX_WORD_LENGTH]; char temp[MAX_WORD_LENGTH]; int i, j; // 从键盘输入单词 printf("请输入 %d 个单词,每个单词长度不得超过 %d 个字符:\n", MAX_WORDS, MAX_WORD_LENGTH - 1); for (i = 0; i < MAX_WORDS; i++) { scanf("%s", words[i]); } // 对单词进行排序 for (i = 0; i < MAX_WORDS - 1; i++) { for (j = i + 1; j < MAX_WORDS; j++) { if (strcmp(words[i], words[j]) > 0) { strcpy(temp, words[i]); strcpy(words[i], words[j]); strcpy(words[j], temp); } } } // 输出排序后的单词 printf("排序后的单词为:\n"); for (i = 0; i < MAX_WORDS; i++) { printf("%s\n", words[i]); } return 0; } ``` 该程序使用了一个二维字符数组 `words` 来存储输入单词,其中 `MAX_WORDS` 定义了单词的最大数量,`MAX_WORD_LENGTH` 定义了单词的最大长度(包括结尾的空字符)。 程序首先从键盘输入单词并存储到 `words` 数组中,然后使用冒泡排序单词进行排序,最后输出排序后的单词。注意,在比较单词大小时,使用了 `strcmp()` 函数,该函数可以比较两个字符串的大小,如果第一个字符串小于第二个字符串,则返回一个负数;如果两个字符串相等,则返回0;如果第一个字符串大于第二个字符串,则返回一个正数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值