鱼C论坛

 找回密码
 立即注册
查看: 750|回复: 1

[已解决]我的冒泡排序好像有点问题

[复制链接]
发表于 2023-11-21 20:07:42 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdio.h>
  2. #include <string.h>

  3. void input(int num[10],char name[10][10]);
  4. void output(int num[10],char name[10][10]);
  5. void sort(int num[10],char name[10][10]);
  6. int main(){
  7.     int num[10];
  8.     char name[10][10];
  9.     input(num,name);
  10.     printf("\n");
  11.     output(num,name);
  12.     sort(num,name);
  13.     printf("排序后:\n");
  14.     output(num,name);



  15. }

  16. void input(int num[10],char name[10][10]){
  17.     for(int i=0;i<10;i++){
  18.         printf("请输入第%d个职工的编号:",i+1);
  19.         scanf("%d",&num[i]);
  20.         getchar();
  21.         printf("请输入第%d个职工的姓名:",i+1);
  22.         gets(name[i]);
  23.     }
  24. }

  25. void output(int num[10],char name[10][10]){
  26.     for(int i=0;i<10;i++){
  27.         printf("编号%d,姓名:%s\n",num[i],name[i]);
  28.     }
  29. }


  30. void sort(int num[10],char name[10][10]){
  31.     for(int i=0;i<9;i++){
  32.         for(int j=0;j<9-i;j++){
  33.             if(num[i]>num[i+1])
  34.             {
  35.                 int temp=num[i];
  36.                 num[i] = num[i+1];
  37.                 num[i+1] = temp;
  38.                 char string[10];
  39.                 strcpy(string,name[i]);
  40.                 strcpy(name[i],name[i+1]);
  41.                 strcpy(name[i+1],string);
  42.             }
  43.         }
  44.     }
  45. }
复制代码



排序后的输出并不是由小到大的
最佳答案
2023-11-21 20:07:51
你的冒泡排序算法出现了问题。在你的sort函数中,你使用了两个嵌套的for循环来比较和交换元素,但是在比较和交换元素的地方有一些错误。

首先,你的比较条件应该是 num[j] > num[j+1] ,而不是 num[ i] > num[i+1] 。这是因为你正在使用j来遍历数组,而不是i。

其次,在交换元素的地方,你需要使用j而不是i。所以你的交换代码应该是这样的:

  1. if(num[j] > num[j+1]) {
  2.     int temp = num[j];
  3.     num[j] = num[j+1];
  4.     num[j+1] = temp;
  5.     char string[10];
  6.     strcpy(string, name[j]);
  7.     strcpy(name[j], name[j+1]);
  8.     strcpy(name[j+1], string);
  9. }
复制代码


通过这些修改,你的冒泡排序算法应该能够正确地对编号进行排序。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-21 20:07:51 | 显示全部楼层    本楼为最佳答案   
你的冒泡排序算法出现了问题。在你的sort函数中,你使用了两个嵌套的for循环来比较和交换元素,但是在比较和交换元素的地方有一些错误。

首先,你的比较条件应该是 num[j] > num[j+1] ,而不是 num[ i] > num[i+1] 。这是因为你正在使用j来遍历数组,而不是i。

其次,在交换元素的地方,你需要使用j而不是i。所以你的交换代码应该是这样的:

  1. if(num[j] > num[j+1]) {
  2.     int temp = num[j];
  3.     num[j] = num[j+1];
  4.     num[j+1] = temp;
  5.     char string[10];
  6.     strcpy(string, name[j]);
  7.     strcpy(name[j], name[j+1]);
  8.     strcpy(name[j+1], string);
  9. }
复制代码


通过这些修改,你的冒泡排序算法应该能够正确地对编号进行排序。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 15:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表