Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2124457
  • 博文数量: 288
  • 博客积分: 10594
  • 博客等级: 上将
  • 技术积分: 3469
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-27 19:27
文章分类

全部博文(288)

文章存档

2012年(4)

2011年(30)

2010年(40)

2009年(32)

2008年(71)

2007年(79)

2006年(32)

分类: LINUX

2010-06-01 14:53:02

 

#include <stdio.h>

void bsort(char *arr, int len)
{
    int i, j, k, t, cnt = 0;;

    for(i = len - 1; i > 0; i = k) {

        for (j = 0, k = 0; j < i; j++) {

            if (*(arr + j) > *(arr + j + 1)) {
                t = *(arr + j);
                *(arr + j) = *(arr + j + 1);
                *(arr + j + 1) = t;

                k = j;
            }
        }
        cnt++;
    }

    printf("cycle %d\n", cnt);
}

int main(int argc, char *argv[])
{
    int i = 0;
    char arr[10] = {3, 2, 5, 4, 4, 5, 6, 7, 8, 9};

    while (i < 10) {
        printf("%d ", arr[i++]);
    }
    i = 0;
    putchar('\n');

    bsort(arr, 10);
    
    while (i < 10) {
        printf("%d ", arr[i++]);
    }
    putchar('\n');
}


阅读(1492) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~