标题:选择排序(欢迎测试,如有任何bug请告知,谢谢!)
只看楼主
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
结帖率:95.65%
已结贴  问题点数:20 回复次数:7 
选择排序(欢迎测试,如有任何bug请告知,谢谢!)
欢迎测试,如有任何问题请告知,先行谢过。



程序代码:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
typedef int ET;
void sort( ET *array, int l, int r );

int main( void )
{
    ET a[ 10 ];
    
    srand( ( unsigned )time( NULL) );
    
    for( int i = 0; i < 10; ++i )
    {
        a[ i ] = rand() % 1000;
        printf( "%d ", a[ i ] );
    }
    printf("\n");
    sort( a, 0, 10 );
    
    for( int i = 0; i < 10; ++i )
        printf( "%d ", a[ i ] );
    
    return 0;
}


void sort( ET *array, int l, int r )
{
    int minix, maxix;
    ET min, max;
    int i;
    int t;
    
    while( l < r )
    {
        for( minix = l, maxix = l, i = l + 1; i < r; ++i )
        {
            minix = array[ minix ] < array[ i ] ? minix : i;
            maxix = array[ maxix ] > array[ i ] ? maxix : i;
        }
        
        if( minix == r - 1 || maxix == l )
        {
            if( minix == r - 1 )
            {
                t = maxix;
                max = array[ r - 1 ];
                array[ r - 1 ] = array[ maxix ];
                array[ maxix ] = max;
                min = array[ t ];
                array[ t ] = array[ l ];
                array[ l ] = min;
            }
            else
            {
                t = minix;
                min = array[ l ];
                array[ l ] = array[ minix ];
                array[ minix ] = min;
                max = array[ t ];
                array[ t ] = array[ r - 1 ];
                array[ r - 1 ] = max;
            }
        }
        else
        {
            min = array[ l ];
            array[ l ] = array[ minix ];
            array[ minix ] = min;
            max = array[ r - 1 ];
            array[ r - 1 ] = array[ maxix ];
            array[ maxix ] = max;
        }
        
        ++l;
        --r;
    }
}



搜索更多相关主题的帖子: 测试 int array min max 
2017-08-21 18:05
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:20 
哇~和冒泡排序那同出一脉吧~为啥要发个20分而不是100分~是还打算继续实现其它排序方法么~不知道插入归并和快排等那些还能不能这样~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-08-21 20:11
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:0 
还有有确实实测数据说明这排序比传统排序的效率高么~不仅仅上是原理上的猜测,更重要的是实际数据的执行效率~

[此贴子已经被作者于2017-8-21 20:15编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-08-21 20:14
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:0 
回复 3楼 九转星河
你测试下不就知道了。我手机测试不方便。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-08-21 20:20
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:0 
回复 3楼 九转星河
拿常规写法和这个排序10万个数据,分别执行10次。
然后输出时间就清楚了。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-08-21 20:23
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:0 
回复 2楼 九转星河
插入排序明天再看。今天粗略扫了几眼,明后天再说,有时间就写。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-08-21 20:28
lmlm1001
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:4
帖 子:107
专家分:550
注 册:2015-3-1
得分:0 
to 楼主:
        收回我的话,并且向你道歉!

[此贴子已经被作者于2017-8-22 22:17编辑过]

2017-08-22 21:54
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:0 
回复 7楼 lmlm1001
张嘴就来。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-08-22 22:10



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




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

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