排序2——

今天学习了《啊哈!算法》第一章排序的快速排序和小哼买书算法, so easy 啦~

一、快速排序

我们昨天学习的桶排序和冒泡排序分别存在浪费空间和执行效率较慢的问题,而我们今天学习的快速排序很好的解决了这些问题。

快速排序之所以较快,是因为相比冒泡排序,每次交换是跳跃式的。每次排序的时候设置一个基准点,将小于等于基准点的数全部放到基准点的左边,将大于等于基准点的数全部放到基准点的右边。这样在每次交换的时候就不会像冒泡排序一样只能在相邻的数之间进行交换,交换的距离可大得多了。但在最坏的情况下,仍可能是相邻的两个数进行交换,因此快速排序的最差时间复杂度和冒泡排序是一样的,都是O(N^2),它的平均时间复杂度为O(NlogN)。

其实快速排序是一种“二分”的思想。

例如:将10个数6 1 2 7 9 3 4 5 10 8从小到大排序

#include<stdio.h>
int n,a[101];
int main()
{
    int i,j;
    scanf("%d",&n);
    for(i=1;i<=n;i++){
        scanf("%d",&a[i]);
    }
    qicksort(1,n);
    for(i=1;i<=n;i++){
        printf("%d ",a[i]);
    }
    //getchar();getchar();
    return 0;
}
void qicksort(int left,int right)
{
    int i,j,t;
    int temp;
    if(left>right)
        return;
    temp=a[left];
    i=left;
    j=right;
    while(i!=j)
    {
        while(a[j]>=temp&&i<j)//没找到比基准数小的,往后移
            j--;
        while(a[i]<=temp&&i<j)//没找到比基准数大的,往前移
            i++;
        if(i<j)
        {
            t=a[i];
            a[i]=a[j];
            a[j]=t;
        }
    }
    a[left]=a[i];
    a[i]=temp;
    qicksort(left,i-1);
    qicksort(i+1,right);
    return;
}

二、小哼买书

小哼的学校要建立一个图书角,小哼让每个同学写出一个自己最想读的书的ISBN号,当然有一些好书会有很多同学都喜欢,这样就会收集到很多重复的ISBN号。小哼需要去掉其中重复的ISBN号,即每个ISBN号从小到大排序,小哼按照排序好的ISBN号去书店买书。     请你协助小哼完成“去重”与“排序”的工作。

输入有2行,第一行为一个正整数,表示有n个同学参与调查。第2行有n个用空格隔开的正整数,为每本图书的ISBN号。

输出也是2行,第1行为一个正整数k,表示需要买多少书。第2行为k个用空格隔开的正整数,为从小到大已排好序的需要购买的图书的ISBN号。

例如输入:

10

20 40 32 67 40 20 89 300 400 15

则输出:

8

15 20 32 40 67 89 300 400 

我分别用桶排序、冒泡排序和快速排序求解

//桶排序 

#include<stdio.h>
int main()
{
    int i,t,n;
    int a[1000];
    scanf("%d",&n);
    for(i=1;i<=1000;i++)
        a[i]=0;
        for(i=1;i<=n;i++){
            scanf("%d",&t);
            a[t]=1;
        }
        for(i=1;i<=1000;i++){
            if(a[i]==1)
                printf("%d ",i);
        }
        return 0;
}

//冒泡排序

#include<stdio.h>
int main()
{
    int i,j,t;
    int n;
    int a[1001];
    scanf("%d",&n);
    for(i=1;i<=n;i++){
        scanf("%d",&a[i]);
    }
    for(i=1;i<n-1;i++){
        for(j=1;j<n-i;j++){
            if(a[j]>a[j+1])
            {
                t=a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            }
        }
    }
    printf("%d ",a[n]);
    for(i=1;i<n;i++){
        if(a[i]!=a[i+1])
            printf("%d ",a[i]);
    }
    return 0;
}

//快速排序

#include<stdio.h>
int a[1001],n;
int main()
{
    int i;
    scanf("%d",&n);
    for(i=1;i<=n;i++){
        scanf("%d",&a[i]);
    }
    qicksort(1,n);
    printf("%d ",a[1]);
    for(i=2;i<=n;i++){
            if(a[i]!=a[i-1])
        printf("%d ",a[i]);
    }
    return 0;
}
void qicksort(int left,int right)
{
    int i,j,t,temp;
    if(left>right)
        return;
    temp=a[left];
    i=left;
    j=right;
    while(i!=j)
    {
        while(a[j]>=temp&&i<j)
            j--;
        while(a[i]<=temp&&i<j)
            i++;
        if(i<j)
        {
            t=a[i];
            a[i]=a[j];
            a[j]=t;
        }
    }
        a[left]=a[i];
        a[i]=temp;
        qicksort(left,i-1);
        qicksort(i+1,right);
        return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值