码迷,mamicode.com
首页 > 编程语言 > 详细

算法排序

时间:2018-03-23 11:38:42      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:冒泡排序   log   一个   nlogn   开始   简单   元素   []   class   

一、插入类排序         因为小编太懒,所以后面没有详细写

1、直接插入排序

{49,38,65,97,76,13,27,_49}

1)插49

49         38,65,97,76,13,27,_49

2)插38

38,49         65,97,76,13,27,_49

以此类推。。。

算法代码:  o(n^2)

void InsertSort(int R[],int n){

  int i,j;

  int temp;

  if(i=2;i<=n;i++){

    temp=R[i];

    j=i-1;

    while(j>=1&&R[j]>temp){

      R[j+1]=R[J];

      j--;

    }

    R[j+1]=temp;

  }

}

2、折半插入排序  o(nlogn)

low\high   

3、希尔排序  哦(nlogn)

又称缩小增量排序,以增量分割序列,

原始序列:49,38,65,97,76,13,27,_49,55,04

以增量5分割序列得到子序列,然后对子序列进行排序得到一趟希尔排序结果

 

二、交换类排序

1、冒泡排序   o(n^2)

void BubbleSort(int r[n],i

  int i,j,flag,temp;

  for(i=n;i>=2;i--){  //比较个数

    flag=0;

    for(j=2;j<=i;j++){

      if(r[j-1]>r[j]){

        temp=r[j];

        r[j]=r[j-1];

        r[j-1]=temp;

        flag=1;

      }

      if(flag==0){return}

    }

  }

}

2、快速排序  “枢纽”   o(nlogn)

三、选择类排序

1、简单选择排序  o(n^2)

从头到尾开始扫描,找出最小的 一个元素,和第一个元素交换,接着从剩下的元素中继续选择和交换

2、堆排序  o(logn)

 

算法排序

标签:冒泡排序   log   一个   nlogn   开始   简单   元素   []   class   

原文地址:https://www.cnblogs.com/xiaoan0705/p/8628853.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!