我的日常

登录/注册
您现在的位置:论坛 资料库 JAVA开发 > 插入排序算法
总共48086条微博

动态微博

查看: 1276|回复: 1

插入排序算法

[复制链接]
admin    

1244

主题

544

听众

1万

金钱

管理员

  • TA的每日心情

    2021-2-2 11:21
  • 签到天数: 36 天

    [LV.5]常住居民I

    管理员

    跳转到指定楼层
    楼主
    发表于 2015-07-16 21:34:09 |只看该作者 |倒序浏览
    1、算法描述

    1,从第一个元素开始,该元素可以认为已经被排序;
    2,取出下一个元素,在已经排序的元素序列中从后向前扫描。
    3,如果该元素(已排序)大于新元素,将该元素移到下一位置。
    4,重复步骤3 ,直到找到已排序的元素小于或者等于新元素的位置。
    5,将新元素插入到该位置中。
    6,重复步骤2。

    2、java代码
    public class InsertSort
    {
        public void insertSort(int[] a)
        {
            for(int j=1;j<a.length;j++)
            {
                int temp=a[j],i=j;
                while(i>=1&&a[i-1]>temp)
                {
                    a[i]=a[i-1];
                    i--;
                }
                a[i]=temp;
            }
        }

        public static void main(String[] args)
        {
            int[] a=new int[]{3,5,6,4,1,2};
            InsertSort sort=new InsertSort();
            sort.insertSort(a);
        }
    }
    3、时间复杂度分析
    函数内部包含一个for循环,循环次数跟数组的长度n一样,循环内部的 int temp=a[j],i=j;和 a[i]=temp;为基础语句,执行时间为常量a,执行次数为n。主要就看for循环内部的while部分,while内部的语句a[i]=a[i-1];和i--;为基础语句,执行时间为常量a,就看执行次数了。while的执行次数由j和数组中元素的排列顺序控制,分三种情况:

    1)、最好情况

    数组中元素按从小到大排列,则while内部语句不会执行,次数时间复杂度为O(n).

    2)、最坏情况

    数组中元素按从大到小排列,则while执行次数为:1+2+3+...+(n-1)=\(\frac{(n-1)n}{2}\)=O(n^2)

    3)、随机顺序

    这个该如何


    科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、科帮网管理员和版主有权不事先通知发贴者而删除本文


    JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

    1

    主题

    0

    听众

    348

    金钱

    四袋长老

    该用户从未签到

    沙发
    发表于 2016-05-15 20:44:30 |只看该作者
    会的真多,望尘莫及
    回复

    使用道具 举报

    快速回复
    您需要登录后才可以回帖 登录 | 立即注册

       

    关闭

    站长推荐上一条 /1 下一条

    发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
    快速回复 返回顶部 返回列表