头歌--交换类排序

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

#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 **********/

  • 22
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值