| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 485 人关注过本帖
标题:分享排列一小例(0,1, 2)
只看楼主 加入收藏
madfrogme
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:21
帖 子:1160
专家分:1106
注 册:2009-6-24
结帖率:98.63%
收藏
已结贴  问题点数:20 回复次数:7 
分享排列一小例(0,1, 2)
大牛们的问题做不来, 也就自娱自乐的看一些简单的小问题哈, 拿来分享一下

不是什么复杂的问题,

是一个排列0,1, 2 的问题, 好像和德国国旗问题什么的怪像的( Dutch national flag problem.)

也就是给定一个数组 {0, 1, 1, 0, 1, 2, 1, 2, 0, 0, 0, 1};

 然后排好队就行了, {0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2}


直接给程序太生硬,给个连接吧,里面有解释

http://www.csse.monash.edu.au/~lloyd/tildeAlgDS/Sort/Flag/

因为感觉只是要排列三种数,所以没那么复杂了

Time Complexity: O(n)

程序代码:
#include <stdio.h>

void swap(int *a, int *b);

void sort012(int a[], int arr_size) {

    int lo = 0;
    
    int hi = arr_size - 1;

    int mid = 0;

    while( mid <= hi ) {

        switch ( a[mid] ) {
            
            case 0:
                swap ( &a[lo++], &a[mid++] );
                break;

            case 1:
                mid++;
                break;

            case 2:
                swap ( &a[mid], &a[hi--]);
                break;
        }
    }
}

void swap(int *a, int *b) {

    int temp = *a;

    *a = *b;

    *b = temp;
}

void printArray(int arr[], int arr_size) {

    int i;

    for( i = 0; i < arr_size; i++)

        printf("%d ", arr[i] );
    
    printf("\n");
}

int main(void) {

    int arr[] = {0, 1, 1, 0, 1, 2, 1, 2, 0, 0, 0, 1};

    int arr_size = sizeof( arr ) / sizeof( arr[0] );
    
    int i;
    
    sort012( arr, arr_size );

    printf("array after segregation ");

    printArray( arr, arr_size );

    return 0;
}


[ 本帖最后由 madfrogme 于 2012-8-21 12:29 编辑 ]
搜索更多相关主题的帖子: 自娱自乐 problem national 排列三 
2012-08-21 11:27
justNPC
Rank: 5Rank: 5
等 级:职业侠客
帖 子:101
专家分:311
注 册:2012-8-11
收藏
得分:4 
冒泡排序不就好了么
2012-08-21 12:41
madfrogme
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:21
帖 子:1160
专家分:1106
注 册:2009-6-24
收藏
得分:0 
回复 2楼 justNPC
Time Complexity: O(n) :)

The quieter you become, the more you can hear
2012-08-21 12:57
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:4 
如果是作为学习排序的示例那我就不多说什么了。这个问题本身,根本不需要排序就能解决。

重剑无锋,大巧不工
2012-08-21 13:00
madfrogme
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:21
帖 子:1160
专家分:1106
注 册:2009-6-24
收藏
得分:0 
回复 4楼 beyondyf
杨大哥的意思是算出012各有几个,输出一下就可以了?

那就当它是一个排列的小技巧吧,我也是一点一点来了

不过给出的排列如果是规则的,就有一些多余的比较了

{0, 0, 0, 1, 1, 2, 2, 2, 2}

感觉可以把标识最高位的 hi 放到 最后那个 1 的地方,而不是 最后那个 2

[ 本帖最后由 madfrogme 于 2012-8-21 14:26 编辑 ]

The quieter you become, the more you can hear
2012-08-21 13:21
q215236213
Rank: 4
等 级:业余侠客
威 望:1
帖 子:148
专家分:276
注 册:2012-7-24
收藏
得分:4 
冒泡排序就可以解决排序了
2012-08-21 16:37
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:4 
学习了
2012-08-21 16:54
鱼∞鱼
Rank: 2
等 级:论坛游民
帖 子:31
专家分:67
注 册:2012-6-5
收藏
得分:4 
计数 打印就可以了
2012-08-21 18:53
快速回复:分享排列一小例(0,1, 2)
数据加载中...
 
   



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

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