weixin_44091894 2020-12-25 09:32 采纳率: 80%
浏览 138
已采纳

怎么将冒泡排序法的降序跟升序写进一个void sort函数里

程序功能】 给定整型数组int a[]={12, 13, 56, 78, 34, 47, 77, 94, 23, 63 }; 要求使用函数编程,实现在main函数中输入数值“0 ”,数组则降序排列,输入数值“1”,数组则升序排列,并在main函数中输出排序后的数组。 【编程要求】 通过排序法对数组进行进行升序或者降序排序; 排序在 void sort(int a[], int n)函数中完成,而不是升序与降序各写一个代码类似的函数; 将结果输出到屏幕上。

  • 写回答

3条回答 默认 最新

  • 「已注销」 2020-12-25 10:27
    关注
    #include<stdio.h>
    #include<stdlib.h>
    int increase(const void * a, const void * b)
    {
        return (*(int*)a) - (*(int*)b);
    }
    
    int decrease(const void * a, const void * b)
    {
        return (*(int*)b) - (*(int*)a);
    }
    
    void sort(int * arr, int len,int desc)
    {
        qsort(arr,len,sizeof(int),desc?decrease:increase);
    }
    
    int main()
    {
        int arr[] = {2,3,4,5,6,7,8};
        int len = sizeof(arr)/sizeof(int),i;
        sort(arr,len,1);
        for(i = 0 ; i < len ; i++)
        {
            printf("%d ",arr[i]);
        }
        sort(arr,len,0);
        printf("\n");
        for(i = 0 ; i < len ; i++)
        {
            printf("%d ",arr[i]);
        }
        printf("\n");
    }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥50 adb连接不到手机是怎么回事?
  • ¥15 vs2022无法联网
  • ¥15 TCP的客户端和服务器的互联
  • ¥15 VB.NET操作免驱摄像头
  • ¥15 笔记本上移动热点开关状态查询
  • ¥85 类鸟群Boids——仿真鸟群避障的相关问题
  • ¥15 CFEDEM自带算例错误,如何解决?
  • ¥15 有没有会使用flac3d软件的家人
  • ¥20 360摄像头无法解绑使用,请教解绑当前账号绑定问题,
  • ¥15 docker实践项目