写一个算法对1,8,5,2,4,9,7进行顺序排列并给出所使用的算法,并简述算法实现原理及时间复杂度
冒泡排序
原理:第一趟在序列(A[0]~A[n-1])中从前往后进行两个相邻元素的比较,若后者小,则交换,比较 n-1 次;第一趟排序结束,最大元素被交换到A[n-1]中,下一趟排序只需要在子序列(A[0]~A[n-2])中进行;冒泡排序最多进行 n-1 趟 。基本的冒泡排序可以利用旗标的方式稍微减少一些比较的时间,当寻访完序列后都沒有发生任何的交换动作,表示排序已经完成,而无需再进行之后的比较与交换动作 。public class OrderbyArray { //冒泡排序 Bubble Sort 最简单的排序方法是冒泡排序方法 public int[] orderArray(int[] array){for(int i=0;i<array.length;i++){for(int j=i;j<array.length;j++){if(array[i]>array[j]){int s = array[i];array[i] = array[j];array[j] = s;}}}return array; } public static void main(String[] args) {int [] array = {1,8,5,2,4,9,7};OrderbyArray order = new OrderbyArray();array = order.orderArray(array);}}
文章插图
选择排序
原理:将初始序列(A[0]~A[n-1])作为待排序序列,第一趟在待排序序列(A[0]~A[n-1])中找到最小值元素,将其与第一个元素A[0]交换,这样子序列(A[0])已经有序,下一趟在排序在待排序子序列(A[1]~A[n-1])中进行 。第i趟排序在待排序子序列(A[i-1]~A[n-1])中找到最小值元素,与该子序列中第一个元素A[i-1]交换 。经过 n-1 趟排序后使得初始序列有序 。冒泡和选择都为 O(
推荐阅读
- linux后台执行命令:&和nohup的用法
- 和红茶有关的几个认识误区
- 分布式ID生成--雪花算法
- 大红袍和铁观音区别采摘时间区别
- 茶叶的种类和功效与作用不同茶不同功效
- 红茶和绿茶的区别四个分别方法
- 梦见去世妈妈和在世的爸爸坐在一起吃饭,妈妈没吃 梦见去世妈妈和在世的爸爸一起修旧房子
- 云南红茶和祁门红茶的区别六个区别
- 茶叶的种类和名字根据制作工艺分为六个种类
- 怎么区分月季花茶和玫瑰花茶月季和玫瑰花的区别