快乐打码 2022-11-06 13:21 采纳率: 69.8%
浏览 49
已结题

请问我这哪错了,为什么我得不到我想要的答案,是哪错了吗?要怎么改正

7-8 冒泡法排序

将N个整数按从小到大排序的冒泡排序法是这样工作的:从头到尾比较相邻两个元素,如果前面的元素大于其紧随的后面元素,则交换它们。通过一遍扫描,则最后一个元素必定是最大的元素。然后用同样的方法对前N−1个元素进行第二遍扫描。依此类推,最后只需处理两个元素,就完成了对N个数的排序。

本题要求对任意给定的K(<N),输出扫描完第K遍后的中间结果数列。

输入格式:
输入在第1行中给出N和K(1≤K<N≤100),在第2行中给出N个待排序的整数,数字间以空格分隔。

输出格式:
在一行中输出冒泡排序法扫描完第K遍后的中间结果数列,数字间以空格分隔,但末尾不得有多余空格。

输入样例:
6 2
2 3 5 1 6 4
输出样例:
2 1 3 4 5 6

#include<stdio.h>
void bubble_sort(int arr,int N){
    int i=0;
    int k;
    for(i=0;i<N-1;i++){
        int j=0;
        for(j=0;j<=k;j++){
            if(arr[j]>arr[j+1])
            int tmp=arr[j];
            arr[j]=arr[j+1];
            arr[j+1]=tmp;
            if(j==1){printf("%d",arr[j]);}
            else {printf(" %d",arr[j]);}
        }
        
    }
}
int main(){
    int N,K;
    scanf("%d%d\n",&N,&k);
    int arr[N],i=0;
   for(i=0;i<N-1;i++){
       scanf("%d\n",&arr[i]);
   }
    int bubble_sort(arr,N);
    return 0;
}

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2022-11-06 23:37
    关注

    修改如下,供参考:

    #include<stdio.h>
    #define N 101
    void bubble_sort(int arr[],int n,int k) //修改
    {
        int i,j;
        for(i=0;i<k;i++) //for(i=0;i<N-1;i++)
        {
            for(j=0;j<n-1-i;j++) //for(j=0;j<=k;j++)
            {
                if(arr[j]>arr[j+1])
                {
                    int tmp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=tmp;
                }
                //if(j==1){printf("%d",arr[j]);}
                //else {printf(" %d",arr[j]);}
            }
        }
    }
    int main(){
        int n,K;
        scanf("%d%d",&n,&K);  //("%d%d\n",&N,&k);
        int arr[N],i=0;
        for(i=0;i<n;i++){     //for(i=0;i<N-1;i++)
           scanf("%d",&arr[i]);//("%d\n",&arr[i])
        }
        bubble_sort(arr,n,K);  //int bubble_sort(arr,N);
    
        for(i=0;i<n;i++)       //修改,增加输出
            printf(i==0?"%d":" %d",arr[i]);
    
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月15日
  • 已采纳回答 11月7日
  • 创建了问题 11月6日

悬赏问题

  • ¥20 iOS绕地区网络检测
  • ¥15 python验证码滑块图像识别
  • ¥15 根据背景及设计要求撰写设计报告
  • ¥15 QT6颜色选择对话框显示不完整
  • ¥20 能提供一下思路或者代码吗
  • ¥15 用twincat控制!
  • ¥15 请问一下这个运行结果是怎么来的
  • ¥15 单通道放大电路的工作原理
  • ¥30 YOLO检测微调结果p为1
  • ¥15 DS18B20内部ADC模数转换器