小羊爱吃小草 发表于 2023-11-9 10:33:44

哪里有问题

#include <stdio.h>

int main()
{
        int i=0, j, temp,arr;
        printf("input 10 numbers\n");
        scanf("%d", &arr);

        for(i = 0; i < 10; i++)
        {
                for(j=0; j<i-1; j++)

                if(arr > arr)
                {
                        temp=arr;
                        arr=arr;
                        arr=temp;
                }
                printf("sorted:\n");
                for(i = 0; i<10; i++)
                        printf("%d", arr);
        }

                return 0;



        }

isdkz 发表于 2023-11-9 10:35:13

问题所在是在内层循环的条件判断和交换位置的逻辑上。以下是修正后的代码:

#include <stdio.h>

int main()
{
    int i=0, j, temp, arr;
    printf("input 10 numbers\n");
   
    for(i = 0; i < 10; i++)
    {
      scanf("%d", &arr[ i]);
    }

    for(i = 0; i < 9; i++)
    {
      for(j = 0; j < 9 - i; j++)
      {
            if(arr > arr)
            {
                temp = arr;
                arr = arr;
                arr = temp;
            }
      }
    }
   
    printf("sorted:\n");
    for(i = 0; i < 10; i++)
    {
      printf("%d ", arr[ i]);
    }
   
    return 0;
}


修正的地方包括:

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

修正后的代码可以正确地对输入的10个数字进行冒泡排序,并打印出排序后的结果。
页: [1]
查看完整版本: 哪里有问题