题8.11:在主函数中输入10个等长的字符串。用另一函数对它们排序。然后在主函数输 出这10个已排好序的字符串。

题目

本题是谭浩强《C程序设计课后习题》题8.11。
题目:
在主函数中输入10个等长的字符串。用另一函数对它们排序。然后在主函数输
出这10个已排好序的字符串。


以下是本篇文章正文内容,欢迎朋友们进行指正,一起探讨,共同进步。——来自考研路上的lwj

一、解题思路

思路:
1.使用strcmp字符串比较函数进行比较,使用strcpy字符串拷贝函数用于交换,核心使用冒泡排序算法。
2,本题使用冒泡排序的两种情况:从小到大排序和从大到小排序,均以通过编译运行正确。

二、代码部分

1.引入库

代码如下(示例):

#include<stdio.h> 
#include<string.h>
int i, j;

2.主函数部分

代码如下(示例):

void strsort1(char str1[][32], int n)//冒泡排序法,从小到大排序
{
	for (i = 0; i < n-1; i++)
		for (j = 0; j < n-i-1; j++)
			if (strcmp(*(str1 + j), *(str1 + j+1)) > 0)
			{
				char tmp[32];
				strcpy(tmp, *(str1 + j));
				strcpy(*(str1 + j), *(str1 + j+1));
				strcpy(*(str1 + j+1), tmp);
			}
}
void strsort2(char str1[][32], int n)//冒泡排序法,从大到小排序
{
	for(i=0;i<n;i++)
		for (j = i + 1; j < n; j++)
			if (strcmp(*(str1 + i), *(str1 + j)) < 0)
			{
				char tmp[32];
				strcpy(tmp, *(str1 + i));
				strcpy(*(str1 + i), *(str1 + j));
				strcpy( *(str1 + j),tmp);
			}
}
int main()
{
	char str1[32][32];
	printf("请输入字符串的个数:");
	int n;
	scanf("%d", &n);
	for (i = 0; i < n; i++)
	{
		scanf("%s", str1[i]);
	}
	strsort1(str1, n);
	for (i = 0; i < n; i++)
	{
		printf("%s\n", str1[i]);
	}
	return 0;
}

三、执行结果

在这里插入图片描述

输出:

请输入字符串的个数:5
a
abc
ab
abcd
abcde
a
ab
abc
abcd
abcde
好的,以下是使用 C 语言编写的程序,可以在主函数输入 10 个等长字符串,然后使用另一个函数将它们排序,并在主函数排序后的字符串: ```c #include <stdio.h> #include <string.h> void sort_strings(char str[][100], int n); int main() { char str[10][100]; int i; printf("请输入 10 个等长字符串:\n"); for (i = 0; i < 10; i++) { printf("第 %d 个字符串:", i + 1); fgets(str[i], 100, stdin); str[i][strlen(str[i]) - 1] = '\0'; // 去掉换行符 } sort_strings(str, 10); printf("排序后的字符串为:\n"); for (i = 0; i < 10; i++) { printf("%s\n", str[i]); } return 0; } void sort_strings(char str[][100], int n) { int i, j; char temp[100]; for (i = 0; i < n - 1; i++) { for (j = i + 1; j < n; j++) { if (strcmp(str[i], str[j]) > 0) { strcpy(temp, str[i]); strcpy(str[i], str[j]); strcpy(str[j], temp); } } } } ``` 在这个程序,我们首先定义了一个二维字符数组 `str`,用于存储输入的 10 个字符串。然后,我们使用一个 `for` 循环来逐一输入这些字符串,注意使用 `fgets` 函数读取输入,并且去掉输入字符串的换行符。 接下来,我们调用了一个名为 `sort_strings` 的函数,用于对输入字符串进行排序。该函数接收两个参数,第一个参数是一个二维字符数组,表示需要排序字符串集合;第二个参数是一个整数,表示字符串的个数。 在 `sort_strings` 函数,我们使用两个嵌套的 `for` 循环来实现排序。在外层循环,我们依次处理每一个字符串,然后在内层循环,将当前字符串与后面的字符串逐一比较,如果当前字符串比后面的字符串大,则交换它们的位置。这样,经过几轮比较和交换后,字符串数组就被排好序了。 最后,在主函数,我们好序字符串,注意在时每个字符串后面需要加上换行符。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

立志冲海大

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

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

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

打赏作者

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

抵扣说明:

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

余额充值