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 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
  • ¥15 QTOF MSE数据分析
  • ¥15 平板录音机录音问题解决
  • ¥15 请问维特智能的安卓APP在手机上存储传感器数据后,如何找到它的存储路径?