标题:帮忙看看这个程序--在一组随机排列的数中找出第k小的数(基于快速排序)
只看楼主
xiaolinmax
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2013-9-8
结帖率:100%
已结贴  问题点数:20 回复次数:2 
帮忙看看这个程序--在一组随机排列的数中找出第k小的数(基于快速排序)
#include <stdio.h>
#define LEN 8

int a[LEN] = {1, 46, 7, 32, 75, 34, 678, 35};

int partition(int start, int end)
{
    int i = start;
    int j = end;
    int pivot = a[start];

    while (i < j){
        while (i < j && pivot <= a[j])
            j--;
        a[i] = a[j];
        while (i < j && pivot >a[i])
            i++;
        a[j] = a[i];
    }
    a[i] = pivot;
    return i;
}

int order_statistic(int start, int end ,int k)
{
    int mid ;
    mid = partition(start, end);                    //用partition函数把序列分成两半,中间的pivot元素是序列中的第i个;
    if(k == mid)
        return a[mid-1];                            //返回找到的元素;
    else if(k > mid)
        order_statistic(mid+1, end , k-mid);            //从后半部分找出第k-i小的元素并返回;
    else
        order_statistic(start, mid-1, k);            //从前半部分找出第k小的元素并返回;
}

int main(void)
{
    int value;
    int i;
    value = order_statistic(0, LEN-1, 3);
    printf("%d\n", value);
    for(i = 0; i < LEN; i++)
        printf("%d ", a[i]);
    return 0;
}
搜索更多相关主题的帖子: include return start 
2015-09-04 20:52
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
得分:14 
程序代码:
int order_statistic(int start, int end, int k)
{
    int mid = partition(start, end);

    if (start + k - 1 == mid)
    {
        return a[mid];
    }
    else if (start + k - 1 > mid)
    {
        return order_statistic(mid + 1, end, k - mid - 1);  // 0号位不用就不用减1了
    }
    else
    {
        return order_statistic(start, mid - 1, k);
    }
}


实在不明白你返回 a[mid-1] 是什么意思

[ 本帖最后由 azzbcc 于 2015-9-4 23:28 编辑 ]


[fly]存在即是合理[/fly]
2015-09-04 23:23
xiaolinmax
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2013-9-8
得分:0 
回复 2楼 azzbcc
在寻找第7小时会出错额
2015-09-04 23:39



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-457008-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.736496 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved