鱼C论坛

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

[已解决]哪里有问题

[复制链接]
发表于 2023-11-9 10:33:44 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         int i=0, j, temp,arr[10];
  5.         printf("input 10 numbers\n");
  6.         scanf("%d", &arr[i]);

  7.         for(i = 0; i < 10; i++)
  8.         {
  9.                 for(j=0; j<i-1; j++)

  10.                 if(arr[i] > arr[i+1])
  11.                 {
  12.                         temp=arr[i];
  13.                         arr[i]=arr[i+1];
  14.                         arr[i+1]=temp;
  15.                 }
  16.                 printf("sorted:\n");
  17.                 for(i = 0; i<10; i++)
  18.                         printf("%d", arr[i]);
  19.         }

  20.                 return 0;



  21.         }
复制代码
最佳答案
2023-11-9 10:35:13
问题所在是在内层循环的条件判断和交换位置的逻辑上。以下是修正后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int i=0, j, temp, arr[10];
  5.     printf("input 10 numbers\n");
  6.    
  7.     for(i = 0; i < 10; i++)
  8.     {
  9.         scanf("%d", &arr[ i]);
  10.     }

  11.     for(i = 0; i < 9; i++)
  12.     {
  13.         for(j = 0; j < 9 - i; j++)
  14.         {
  15.             if(arr[j] > arr[j+1])
  16.             {
  17.                 temp = arr[j];
  18.                 arr[j] = arr[j+1];
  19.                 arr[j+1] = temp;
  20.             }
  21.         }
  22.     }
  23.    
  24.     printf("sorted:\n");
  25.     for(i = 0; i < 10; i++)
  26.     {
  27.         printf("%d ", arr[ i]);
  28.     }
  29.    
  30.     return 0;
  31. }
复制代码


修正的地方包括:

1. 将输入数字的部分移动到循环外,以便能够逐个读取10个数字。
2. 内层循环的条件判断应为  j < 9 - i ,因为每一轮外层循环后,最大的元素已经被放置到了正确的位置上,所以不需要再比较。
3. 在打印排序后的数组时,需要在每个数字后面添加一个空格,以便更好地区分各个数字。

修正后的代码可以正确地对输入的10个数字进行冒泡排序,并打印出排序后的结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-9 10:35:13 | 显示全部楼层    本楼为最佳答案   
问题所在是在内层循环的条件判断和交换位置的逻辑上。以下是修正后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int i=0, j, temp, arr[10];
  5.     printf("input 10 numbers\n");
  6.    
  7.     for(i = 0; i < 10; i++)
  8.     {
  9.         scanf("%d", &arr[ i]);
  10.     }

  11.     for(i = 0; i < 9; i++)
  12.     {
  13.         for(j = 0; j < 9 - i; j++)
  14.         {
  15.             if(arr[j] > arr[j+1])
  16.             {
  17.                 temp = arr[j];
  18.                 arr[j] = arr[j+1];
  19.                 arr[j+1] = temp;
  20.             }
  21.         }
  22.     }
  23.    
  24.     printf("sorted:\n");
  25.     for(i = 0; i < 10; i++)
  26.     {
  27.         printf("%d ", arr[ i]);
  28.     }
  29.    
  30.     return 0;
  31. }
复制代码


修正的地方包括:

1. 将输入数字的部分移动到循环外,以便能够逐个读取10个数字。
2. 内层循环的条件判断应为  j < 9 - i ,因为每一轮外层循环后,最大的元素已经被放置到了正确的位置上,所以不需要再比较。
3. 在打印排序后的数组时,需要在每个数字后面添加一个空格,以便更好地区分各个数字。

修正后的代码可以正确地对输入的10个数字进行冒泡排序,并打印出排序后的结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-21 14:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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