| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2947 人关注过本帖, 7 人收藏
标题:对排序的一点研究(选择排序,交换排序,插入排序)。望补充。
只看楼主 加入收藏
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:5 
时间复杂度/空间复杂度不能两全。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-02-17 21:54
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:0 
回复 11楼 ansic
这是肯定的,算法本就是在找平衡而已。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-02-18 08:57
xdzsm
Rank: 2
等 级:论坛游民
帖 子:137
专家分:99
注 册:2010-10-26
收藏
得分:5 
只有相对好的,没有绝对好的!
2011-02-18 11:00
lyj23
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:168
专家分:140
注 册:2010-10-31
收藏
得分:10 
小小补充一点:你可以用位运算^的方法交换,不需要用到临时变量
2011-02-18 11:12
点线面
Rank: 8Rank: 8
来 自:NO.-1
等 级:蝙蝠侠
帖 子:525
专家分:980
注 册:2011-1-3
收藏
得分:0 
以下是引用lyj23在2011-2-18 11:12:38的发言:

小小补充一点:你可以用位运算^的方法交换,不需要用到临时变量
对,不过这个有缺点,一定要尽力避免,不然就是错。

小代码,大智慧
2011-02-18 11:18
草狼
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:577
专家分:1040
注 册:2010-4-6
收藏
得分:0 
貌似还有个基数排序,在数不怎么大的时候可以O(n)的时间复杂度排序
2011-02-18 12:17
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:0 
回复 14楼 lyj23
这倒确实可以,有些交换就不用额外占空间了,不过位运算比占空间搞脑子啊。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-02-18 21:44
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:0 
回复 16楼 草狼
有代码吗?谢谢。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-02-18 21:44
草狼
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:577
专家分:1040
注 册:2010-4-6
收藏
得分:10 
回复 18楼 waterstar
#include<stdio.h>
int main(){
    int num[10]={1,8,2,3,6,5,7,10,9,4},num1[10];
    int tem[12]={0},i;
    for( i=0; i<10; ++i ) tem[ num[i] ]++;
    for( i=1; i<12; ++i ) tem[i]+=tem[i-1];
    for( i=9; i>=0; --i ) num1[--tem[num[i]]]=num[i];
    for( i=0; i<10; ++i ) printf("%d ",num1[i]);
    printf("\n");
    return 0;
}

基数排序如果数据很大时间复杂度就要O(n*m) 其中n是要排序个数字个数,m是要排序的数字中最大那个数字的位数
2011-02-18 22:01
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:5 
学习了
2011-02-19 00:17
快速回复:对排序的一点研究(选择排序,交换排序,插入排序)。望补充。
数据加载中...
 
   



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

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