在主函数中输入10个等长的字符串。用另一函数对它们 排序。然后在主函数输出这10个已排好序的字符串。 要求采用指向一维数组的指针作函数参数,该排序函数 的声明如下:void sort(char (*s

在主函数中输入10个等长的字符串。用另一函数对它们排序。然后在主函数输出这10个已排好序的字符串。要求采用指向一维数组的指针作函数参数,该排序函数的声明如下:void sort(char (*s)[20]);

思路:
1.输入字符串
2.使用冒泡法进行排序
3.输出

#include <stdio.h>
#include <string.h>
#define num 10
char zfc[20][20];
void sort(char *s[20]); // 指针数组
int main()
{  
   char *str[20];
   int i;
   
   for(i=0; i<num; i++)
	   str[i] = zfc[i];
   for(i=0; i<num; i++)
       scanf("%s", str[i]);
   sort(str);
   
return 0;
}

void sort(char *s[20])
{
     int i,j;
	 char *temp;

	 for(i=0; i<num-1; i++)
		 for(j=0; j<num-1-i; j++)
		 {
		     if(strcmp(*(s+j), *(s+j+1)) > 0)
			 {
			     temp = *(s+j);    
				 *(s+j) = *(s+j+1);
				 *(s+j+1) = temp;
			 }
		 }
	 for(i=0;i<num;i++)
		 printf("%s\n",s[i]); 
}
  • 6
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用 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` 循环来实现排序。在外层循环,我们依次处理每一个字符串,然后在内层循环,将当前字符串与后面的字符串逐一比较,如果当前字符串比后面的字符串大,则交换它们的位置。这样,经过几轮比较和交换后,字符串数组就被排好序了。 最后,在主函数,我们输出好序字符串,注意在输出时每个字符串后面需要加上换行符。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值