首页 > 其他分享 >头歌--交换类排序

头歌--交换类排序

时间:2024-06-05 15:32:12浏览次数:19  
标签:-- void int 头歌 swap output input 排序 low

本关任务:编写函数通过比较数组相邻两个元素求数组最大值。

#include <stdio.h>

#include<stdlib.h>

void input(int *&a,int & n);

void output(int *a,int n);

void comp(int *a, int n) ;

void swap(int &a, int &b);

int main ()

{

    int i,n;

    int *a = NULL;  

    input (a,n);

    comp(a, n) ;

    output(a,n);

    free(a);

    return 0;

}

/**********定义函数**********/

/********** Begin **********/

void input(int *&a, int &n) {

    scanf("%d", &n);

    a = (int *)malloc(n * sizeof(int));

    if (a == NULL) {

        exit(1);

    }

    for (int i = 0; i < n; i++) {

        scanf("%d", &a[i]);

    }

}

void output(int *a, int n) {

    for (int i = 0; i < n; i++) {

        printf("%d ", a[i]);

    }

    printf("\n");

}

void comp(int *a, int n) {

    for (int i = 0; i < n - 1; i++) {

        if (a[i] > a[i + 1]) {

            swap(a[i], a[i + 1]);

        }

    }

}

void swap(int &a, int &b) {

    int temp = a;

    a = b;

    b = temp;

}

/********** End **********/

本关任务:编写函数实现冒泡排序。

#include <stdio.h>

#include<stdlib.h>

#include<time.h>

void input(int *&a,int & n);

void output(int *a,int n);

void comp(int *a, int n) ;

void swap(int &a, int &b);

void Bubble_sort(int *a,int n);

int main ()

{

    int i,n;

    int *a = NULL;  

    input (a,n);

    Bubble_sort(a, n) ;

    free(a);

    return 0;

}

void input(int *&a,int & n)

{

    int i;

    scanf("%d",&n);    

    if((a=(int *) malloc ((n)*sizeof(int)))==NULL)

    {

        printf("不能成功分配内存单元\n");

        exit(0);

    }

    for(i=0;i<n;i++)

    {

        scanf("%d",&a[i]);

    }            

}

void output(int *a,int n)

{

    int i;

    for(i=0;i<n;i++)

    {

        printf("%d ",a[i]);

    }

    printf("\n");

}

void swap(int &a, int &b)

{

    int t;

    t=a;a=b;b=t;

}

/**********定义Bubble_sort()函数**********/

/********** Begin **********/

void Bubble_sort(int *a,int n)

{

    int i, j;

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

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

            if (a[j] > a[j + 1]) {

                swap(a[j], a[j + 1]);

            }

        }

        output(a, n);

    }

}

/********** End **********/

本关任务:编写函数实现快速排序的递归算法。

#include <stdio.h>

#include<stdlib.h>

void input(int *&a,int & n);

void output(int *a,int n);

void swap(int &a, int &b);

int Partition(int a[],int low,int high);    

void QuickSort(int a[],int s,int t);

int n;

int main ()

{

    int i;

    int *a = NULL;  

    input (a,n);

    QuickSort(a, 0, n-1) ;  

    free(a);

    return 0;

}

void input(int *&a,int & n)

{

    int i;

    scanf("%d",&n);    

    if((a=(int *) malloc ((n)*sizeof(int)))==NULL)

    {

        printf("不能成功分配内存单元\n");

        exit(0);

    }

    for(i=0;i<n;i++)

    {

        scanf("%d",&a[i]);

    }            

}

void output(int *a,int n)

{

    int i;

    for(i=0;i<n;i++)

    {

        printf("%d ",a[i]);

    }

    printf("\n");

}

void swap(int &a, int &b)

{

    int t;

    t=a;a=b;b=t;

}

/**********定义Partition() 和 QuickSort()函数**********/

/********** Begin **********/

int Partition(int a[],int low,int high){

    int t,key=a[low];

    while(low<high){

        while(low<high && a[high]>=key) --high;

        swap(a[low],a[high]);

        while(low<high && a[low]<=key) ++low;

        swap(a[low],a[high]);

    }

    return low;

}

void QuickSort(int a[],int s,int t){

    int pivo;

    if(s<t){

        pivo=Partition(a,s,t);

        output(a,n);

        QuickSort(a,s,pivo-1);

        QuickSort(a,pivo+1,t);

       

    }

}

/********** End **********/

标签:--,void,int,头歌,swap,output,input,排序,low
From: https://blog.csdn.net/2301_79408901/article/details/139473607

相关文章

  • 分库分表方案
    文章目录分库分表设计思路hash取模和范围方案最终方案采用hash取模和rang范围两者相结合分库分表设计思路首先分库分表有两种方式,一种是垂直拆分,一种是水平拆分。垂直拆分垂直拆分比较简单,也就是本来一个数据库,数据量大之后,从业务角度进行拆分多个库,就是一微服务......
  • 定时任务详解
    文章目录定时任务详解JDK自带第三方任务调度框架java有哪些定时任务的框架为什么需要定时任务定时任务扫表的方案有什么缺点Quartzxxl-jobxxl-job详解elastic-job定时任务详解在定时任务中,操作系统或应用程序会利用计时器或定时器来定期检查当前时间是否达到了预定......
  • 根据用户显式内容——静态web网站与动态web网站
    根据用户显式变化的内容     就像企业的Web网站一样,无论浏览网站的用户是谁,在什么时候访问,总是显式相同内容,这样的网站被称为静态Web网站;与此相对,用户发帖,不同人登录后显式不同内容的网站被称为动态Web网站。     搜索引擎,社交媒体。购物网站等都是动态W......
  • 划分GUI应用的功能
    开发Web应用和桌面应用等需要处理GUI的应用时,经常会遇到设计变更的问题。如果是小规模的程序,从输入的处理到数据的保存,输出,只使用一份代码来实现,几乎不会有什么问题。但是,当规模越来越大,就会有其他开发者和设计师等人参与进来。此时,如果只用一份代码进行管理,当设计师想要稍微......
  • 主动基金如何选?
    主动基金好不好完全看人。主要看管理这个基金的基金经理。选择主动基金就是选择基金经理。主动基金筛选标注是1.基金成立要在2013年成立2.基金经理管理这个基金至少要经历两个牛熊,而且没有离职。3.基金经理任职期间年化收益率排市场前10名。2013年是上上轮熊市的起点,基金......
  • Affinity Designer for Mac(强大的矢量图设计软件)v2.5.2版
    AffinityDesigner中文版是一款专为设计师打造的强大矢量图形设计软件,它以无与伦比的迅捷、流畅和精确性赢得了设计师们的广泛赞誉。无论您是专注于广告设计、网页设计、图标设计还是用户界面(UI)设计,AffinityDesignerMac版都能为您带来前所未有的高效体验。这款软件将彻底革新......
  • Affinity Photo for Mac(专业级图像处理软件)v2.5.2版
    AffinityPhotoforMac是一款专为Mac用户打造的专业级图像处理软件,具备强大的编辑功能,包括图层管理、滤镜效果和色彩调整等,能够满足从摄影师到设计师以及绘画爱好者的各种图像处理需求。它不仅保持了高性能,还注重用户体验和界面设计,使得操作更加直观流畅。此外,AffinityPhoto......
  • Microsoft Remote Desktop for Mac(微软远程连接软件)v10.9.7直装版
    MicrosoftRemoteDesktop是微软开发的远程连接工具,支持Windows、macOS、iOS和Android,允许用户通过互联网远程访问其他计算机的桌面和应用程序,实现跨设备文件共享。同时,它提供网络层身份验证、数据加密和多重身份验证等安全功能,确保用户隐私和数据安全。MicrosoftRemoteDesk......
  • Ansys输配电设备整体解决方案(下)
    结构场和多场耦合应用结构场仿真目的-校核强度和刚度-校核寿命-校核热应力-电磁-结构耦合应用-其他变压器箱体结构强度分析变压器模态计算•计算固有频率•确定共振点装配中的强度设计大型电气设备运输工况分析•精确模拟结构运输实际状态-公路-......
  • 05 Hadoop简单使用
    目录一、hadoop安装配置二、运行hadoop三、hadoop2.x和hadoop3.x变化四、HDFS常用命令五、Java操作HDFS六、MapReduce七、压缩八、yarn常用命令一、hadoop安装配置​1、下载解压hadoop-x.x.x.tar.gztar-xzvfhadoop-x.x.x.tar.gz​2、下载解压jdktar-xzvfj......