头歌--插入类排序

本关任务:编写函数有n(n<=100)个整数,已经按照从小到大顺序排列好,现在另外给一个整数m,请将该数插入到序列中,并使新的序列仍然有序。

#include <stdio.h>

#include<stdlib.h>

#include<time.h>

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

void output(int *a,int n);

void Insert(int *a, int n, int temp) ;

int main ()

{

    int i,n,m;

    int *a = NULL;  

    input (a,n);

    scanf("%d",&m);

    Insert(a, n, m) ;

    output(a,n+1);

    free(a);

   return 0;

}

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

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

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

{

    int i;

    scanf("%d",&n);

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

    for(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]);

    }

}

void Insert(int *a,int n,int temp)

{

    a=(int*)realloc(a,(n+1)*sizeof(int));

    int i=n-1;

    while(i>=0&&a[i]>temp)

    {

        a[i+1]=a[i];

        i--;

    }

    a[i+1]=temp;

}

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

本关任务:编写函数实现直接插入排序算法。

#include <stdio.h>

#include<stdlib.h>

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

void output(int *a,int n);

void InsertSort(int *a,int n);

int main ()

{

    int i,n,m;

    int *a = NULL;  

    input (a,n);

    InsertSort(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;

}

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

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

void InsertSort(int *a,int n)

{

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

        int key = a[i];

        int j = i - 1;

        while (j >= 0 && a[j] > key) {

            a[j + 1] = a[j];

            j = j - 1;

        }

        a[j + 1] = key;

        output(a,n);

    }

}

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

本关要求实现希尔排序的功能。

#include <stdio.h>

#include<stdlib.h>

#include<time.h>

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

void output(int *a,int n);

void ShellInsert(int *L,int n,int dk);

void ShellSort(int *L,int n,int dlta[],int t);

int main ()

{

    int i,n,m;

    int *a = NULL;  

    input (a,n);

    int dlta[3]={5,3,1};

    ShellSort (a, n, dlta, 3) ;

    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;

}

/**********定义ShellInsert() 和 ShellSort()函数**********/

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

void ShellInsert(int *L, int n, int dk) {

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

        int key = L[i];

        int j = i - dk;

        while (j >= 0 && L[j] > key) {

            L[j + dk] = L[j];

            j -= dk;

        }

        L[j + dk] = key;

    }

}

void ShellSort(int *L, int n, int dlta[], int t) {

    for (int k = 0; k < t; k++) {

        ShellInsert(L, n, dlta[k]);

      printf("第%d趟排序结果:\n", k + 1);

        output(L, n);

    }

}

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值