7-11 字符串排序

7-11 字符串排序

#include<stdio.h>
#include<string.h>
#define n 5
int main()
{
    char str[5][81];//多一位用于存放'\0'
    int i;
    int N=n;
    for(i=0;i<5;i++)//输入五个字符串
    {
        scanf("%s",str[i]);
    }
                     
   //sort	
    int j;
	char buf[81];

	for (i = 0; i < n - 1; ++i)
	{
		for (j = 1; j < n - i; ++j)
		{
			if ( strcmp(str[j], str[j - 1]) < 0 )//strcmp函数是string compare(字符串比较)的缩写,用于比较两个字符串并根据比较结果返回整数。基本形式为strcmp(str1,str2),若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数。 [1-2] 
			{
				memset(buf, 0, sizeof(buf));//初始化buf  下面交换
				strcpy(buf, str[j]);
				strcpy(str[j], str[j - 1]);
				strcpy(str[j - 1], buf);
			}
		}
	}
    //print
    	printf("After sorted:\n");

	for (i = 0; i < N; ++i)
	{
		printf("%s\n", str[i]);
	}
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

wy-1226

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值