iistan 发表于 2022-10-15 17:05:06

萌新求助:想让大家看看问题出在哪里

冒泡排序(Bubble Sort),也称为沉降排序(Sinking Sort),之所以称其为冒泡排序,是因为算法中值相对较小的数据会像水中的气泡一样逐渐上升到数组的最顶端。与此同时,较大的数据逐渐地下沉到数组的底部。这个处理过程需在整个数组范围内反复执行多遍。每一遍执行时,比较相邻的两个元素。若顺序不对,则将其位置交换,当没有数据需要交换时,数据也就排好序了。编程将排序函数DataSort()改用冒泡法实现。
**输入格式要求:"%d"提示信息:"Input n:""Input %d numbers:"
**输出格式要求:"Sorting results:""%4d"
程序运行示例如下:
Input n:10
Input 10 numbers: 2 9 3 4 0 6 8 7 5 1
Sorting results:   0   1   2   3   4   5   6   7   8   9

这是我的错误答案
#include<stdio.h>
#define N 40
void DataSort(int a[],int n);
int main()
{
    int n , i , a;
    printf("Input n:");
    scanf(" %d",&n);
    printf("Input %d numbers:",n);
    for(i = 0;i < n;i++ )
    {
      scanf(" %d",&a);
    }
    printf("Sorting results:" );
   DataSort(a, n);
    return0 ;
}
void DataSort(int a[],int n)//排序数组
{
int i , j , k ,temp;
    for(i= 0; i < n - 1; i++ ){
      for( j = i + 1; j < n ;j++){
            if( a < a){
                temp = a;
                a=a;
                a=temp;
            }
      }
      }
      for (i=0;i<n;i++)
    {
      printf("%4d",a);
    }
}


标准答案:
#include <stdio.h>
#include <stdlib.h>
#define N 40

void DataSort(int a[],int n);

void DataSort(int a[],int n)
{
    int i,j,temp;
    for (i=0;i<n-1;i++)
    for (j=0;j<n-1;j++)
    {
      if (a>a)
      {
            temp=a;
            a=a;
            a=temp;
      }
    }
    for (i=0;i<n;i++)
    {
      printf("%4d",a);
    }
}

int main()
{
    int a,n,i;
    printf("Input n:");
    scanf("%d",&n);
    printf("Input %d numbers:",n);
    for (i=0;i<n;i++)
    {
      scanf("%d",&a);
    }
    printf("Sorting results:");
    DataSort(a,n);
    return 0;
}

jackz007 发表于 2022-10-15 17:23:51

本帖最后由 jackz007 于 2022-10-15 17:29 编辑

#include<stdio.h>

#define N 40

void DataSort(int a[] , int n) //排序数组
{
      int i , j , k ,temp;
      for(i = 0; i < n - 1 ; i ++) {
                for(j = i + 1 ; j < n ;j ++) {
                        if(a < a) {
                              temp = a                ;
                              a=a            ;
                              a=temp            ;
                        }
                }
      }
}

int main(void)
{
      int n , i , a                                 ;
      printf("Input n : ")                               ;
      scanf("%d" , & n)                                  ;
      printf("Input %d numbers : " , n)                  ;
      for(i = 0;i < n;i ++) scanf("%d" , & a) ;
      DataSort(a , n)                                    ;
      printf("Sorting results:" )                        ;
      DataSort(a, n)                                     ;
      for(i = 0 ; i < n ; i ++) printf("%4d" , a)   ;
      printf("\n")                                       ;
}
      你的代码基本没有问题,简单整理了一下:
      编译、运行实况:
D:\\C>g++ -o b b.c

D:\\C>b
Input n : 10
Input 10 numbers : 2 9 3 4 0 6 8 7 5 1
Sorting results :    0   1   2   3   4   5   6   7   8   9

D:\\C>
      修改的地方主要是把数据显示从 DataSort() 挪到了 main() 中,其次,就是去掉了 scanf() 格式描述符中的一个前导空格。
页: [1]
查看完整版本: 萌新求助:想让大家看看问题出在哪里