| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 560 人关注过本帖
标题:选择排序法问题
只看楼主 加入收藏
sibswjc
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2012-9-5
结帖率:20%
收藏
已结贴  问题点数:8 回复次数:5 
选择排序法问题
假设数组有10个元素,按照从小到大的顺序排列,请问这两段代码在执行效率上有什么差别,谢谢!
代码一:
    for(i=0;i<=9;i++)
        {for(j=i+1;j<=9;j++)
            if(a[i]>a[j])
            {
            t=a[j];
            a[j]=a[i];
            a[i]=t;
            }
        }
代码二:
         for(i=0;i<=9;i++)
        {k=i;
            for(j=i+1;j<=9;j++)
             if(a[i]>a[j])k=j;
              if(k!=i)
               {
                t=a[i];
                a[i]=a[k];
                a[k]=t;
               }
        }
搜索更多相关主题的帖子: 元素 
2012-12-14 18:02
a151141
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:1
帖 子:197
专家分:680
注 册:2012-10-19
收藏
得分:2 
但看这个程序,基本上差不多,时间复杂度都是n,只不过后一个多一句,每次多执行一次

世界上幸福的事就是抓到一只羊,更幸福的事就是抓到两只羊……
2012-12-14 18:40
sibswjc
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2012-9-5
收藏
得分:0 
回复 2楼 a151141
我怎么觉得时间复杂度应该是n平方呢。
2012-12-14 22:06
神龙赖了
Rank: 10Rank: 10Rank: 10
来 自:萨塔星
等 级:青峰侠
威 望:2
帖 子:711
专家分:1788
注 册:2012-10-13
收藏
得分:2 
唯一的差别就是代码二有问题...
程序代码:
 for(i=0;i<=9;i++)
        {k=i;
            for(j=i+1;j<=9;j++)
             if(a[i]>a[j])
             {
             k=j;  //加中括号,不然if语句只执行k=j,然后继续循环
    
              if(k!=i)
               {
                t=a[i];
                a[i]=a[k];
                a[k]=t;
               }
           }
        } 


 

I have not failed completely
2012-12-14 22:34
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:2 
以下是引用神龙赖了在2012-12-14 22:34:50的发言:

唯一的差别就是代码二有问题... for(i=0;i<=9;i++)
        {k=i;
            for(j=i+1;j<=9;j++)
             if(a>a[j])
             {
             k=j;  //加中括号,不然if语句只执行k=j,然后继续循环
     
              if(k!=i)
               {
                t=a;
                a=a[k];
                a[k]=t;
               }
           }
        }

 
这段代码的确有问题,原因嘛,神龙同学说了

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2012-12-14 22:46
冰冻零点
Rank: 3Rank: 3
来 自:西安电子科技大学
等 级:论坛游侠
帖 子:81
专家分:136
注 册:2012-9-18
收藏
得分:2 
回复 4楼 神龙赖了
代码二有问题,但是我找的不大一样.
代码二:

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

        {k=i;

            for(j=i+1;j<=9;j++)

             if(a[i]>a[j])k=j;
//改为if(a[k]>a[j]) k=j;


              if(k!=i)

               {

                t=a[i];

                a[i]=a[k];

                a[k]=t;

               }

        }

时间都是O(n∧2),不过代码二好上一点点

好好学习,天天向上
2012-12-15 10:29
快速回复:选择排序法问题
数据加载中...
 
   



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

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