当前位置: 首页 > news >正文

wordpress模板创建徐州seo外包

wordpress模板创建,徐州seo外包,常州网站设计,湖北今日头条新闻目录 插入排序 直接插入排序 希尔排序 选择排序 直接选择排序 堆排序 交换排序 冒泡排序 快速排序 递归实现 优化版本 归并排序 插入排序 直接插入排序 public class MySort {public static void insertSort(int[] array) {for (int i 1; i < array.length;…

目录

插入排序

直接插入排序

希尔排序

选择排序

直接选择排序

堆排序

交换排序

冒泡排序

快速排序

递归实现

优化版本

归并排序 


插入排序

直接插入排序

public class MySort {public static void insertSort(int[] array) {for (int i = 1; i < array.length; i++) {int j = i - 1;int tmp = array[i];for (; j >= 0; j--) {if (tmp < array[j]) {array[j + 1] = array[j];} else {break;}}array[j + 1] = tmp;}}
}

· 时间复杂度:

        最好情况下O(n),即数组有序的情况

        最坏情况下O(n^2),即数组逆序的情况

· 空间复杂度:O(1)

· 稳定性: 稳定的排序算法

希尔排序

public class MySort {public static void shellSort(int[] array) {for (int gap = array.length / 2; gap > 1; gap /= 2) {shell(array, gap);}shell(array, 1);}private static void shell(int[] array, int gap) {for (int i = gap; i < array.length; i++) {int j = i - gap;int tmp = array[i];for (; j >= 0; j -= gap) {if (tmp < array[j]) {array[j + gap] = array[j];} else {break;}}array[j + gap] = tmp;}}
}

· 时间复杂度:O(n^1.3)

· 空间复杂度:O(1)

· 稳定性: 不稳定的排序算法

选择排序

直接选择排序

public class MySort {public static void selectSort(int[] array) {for (int i = 0; i < array.length; i++) {int minIndex = i;for (int j = i + 1; j < array.length; j++) {if (array[minIndex] > array[j]) {minIndex = j;}}swap(array, minIndex, i);}}private static void swap(int[] array, int i, int j) {int tmp = array[i];array[i] = array[j];array[j] = tmp;}
}

· 时间复杂度:O(n^2)

· 空间复杂度:O(1)

· 稳定性:不稳定的排序算法 

堆排序

要排升序时,建立大根堆,排降序时,建立小根堆

public class MySort {public static void heapSort(int[] array) {//1、建立大根堆  时间复杂度:O(n)createHeap(array);//2、排序  时间复杂度:O(n*logn)int end = array.length - 1;while (end > 0) {swap(array, 0, end);shiftDown(array, 0, end);end--;}}private static void createHeap(int[] array) {for (int parent = (array.length-1-1) / 2; parent >= 0; parent--) {shiftDown(array, parent, array.length);}}private static void shiftDown(int[] array, int parent, int len) {int child = 2 * parent + 1;while (child < len) {if (child+1 < len && array[child] < array[child+1]) {child++;//他一定保存的是左右孩子的最大值的下标}if (array[child] > array[parent]) {swap(array, child, parent);parent = child;child = 2*parent + 1;} else {break;}}}private static void swap(int[] array, int i, int j) {int tmp = array[i];array[i] = array[j];array[j] = tmp;}
}

· 时间复杂度:O(n*logn)  和数据是否有序无关

· 空间复杂度:O(1)

· 稳定性:不稳定的排序算法 

交换排序

冒泡排序

public class MySort {public static void bubbleSort(int[] array) {for (int i = 0; i < array.length; i++) {boolean flag = false;for (int j = 0; j < array.length - i - 1; j++) {if (array[j + 1] < array[j]) {swap(array, j + 1, j);flag = true;}}if (flag == false) {return;}}}private static void swap(int[] array, int i, int j) {int tmp = array[i];array[i] = array[j];array[j] = tmp;}
}

· 时间复杂度:O(n^2),优化后的冒泡排序时间复杂度最好可以到O(n)

· 空间复杂度:O(1)

· 稳定性:稳定的排序算法 

快速排序

· 时间复杂度:

        最好情况下:O(n*logn),待排序列尽量均匀的分割

        最坏情况下:O(n^2),待排序列正序或逆序

· 空间复杂度:

        最好情况下:O(logn)

        最坏情况下:O(n)

· 稳定性:不稳定的排序算法 

递归实现

public class MySort {public static void quickSort(int[] array) {quick(array, 0, array.length - 1);}private static void quick(int[] array, int start, int end) {if (start >= end) {return;}int pivot = partition(array, start, end);quick(array, start, pivot - 1);quick(array, pivot + 1, end);}private static int partition(int[] array, int left, int right) {int tmp = array[left];while (left < right) {while (left < right && array[right] >= tmp) {right--;}array[left] = array[right];while (left < right && array[left] <= tmp) {left++;}array[right] = array[left];}array[left] = tmp;return left;}
}

优化版本

对于快速排序的优化,利用三数取中法选取key值,当递归到小的区间时,采用直接插入排序

public class MyQuickSort {private static final int INSERT_SIZE = 100;private static void quickSort(int[] array) {quick(array, 0, array.length - 1);}private static void quick(int[] array, int start, int end) {if (start >= end) {return;}if (end - start + 1 <= INSERT_SIZE) {insertSort(array, start, end);return;}int index = threeMid(array, start, end);swap(array, start, index);int pivot = partition(array, start, end);quick(array, start, pivot - 1);quick(array, pivot + 1, end);}/*** 针对快排的优化:key值根据三数取中法获得*/private static int threeMid(int[] array, int left, int right) {int mid = (left + right) >>> 1;if (array[left] > array[right]) {if (array[mid] > array[left]) {return left;} else if (array[mid] < array[right]) {return right;} else {return mid;}} else {if (array[mid] > array[right]) {return right;} else if (array[mid] < array[left]) {return left;} else {return mid;}}}/*** 针对快排的优化:当递归到小的区间时,快排转为插入排序*/private static void insertSort(int[] array, int start, int end) {for (int i = start + 1; i < end + 1; i++) {int j = i - 1;int tmp = array[i];for (; j >= start; j--) {if (tmp < array[j]) {array[j + 1] = array[j];} else {break;}}array[j + 1] = tmp;}}private static int partition(int[] array, int left, int right) {int tmp = array[left];while (left < right) {while (left < right && array[right] > tmp) {right--;}array[left] = array[right];while (left < right && array[left] < tmp) {left++;}array[right] = array[left];}array[left] = tmp;return left;}private static void swap(int[] array, int i, int j) {int tmp = array[i];array[i] = array[j];array[j] = tmp;}
}

归并排序 

public class MySort {public static void mergeSort(int[] array) {mergeSortFunction(array, 0, array.length - 1);}private static void mergeSortFunction(int[] array, int low, int high) {if (low >= high) {return;}int mid = (low + high) >>> 1;mergeSortFunction(array, low, mid);mergeSortFunction(array, mid + 1, high);merge(array, low, high, mid);}private static void merge(int[] array, int low, int high, int mid) {int[] tmp = new int[high - low + 1];int k = 0;int start1 = low;int end1 = mid;int start2 = mid + 1;int end2 = high;while (start1 <= end1 && start2 <= end2) {if (array[start1] < array[start2]) {tmp[k++] = array[start1++];} else {tmp[k++] = array[start2++];}}while (start1 <= end1) {tmp[k++] = array[start1++];}while (start2 <= end2) {tmp[k++] = array[start2++];}for (int i = 0; i < k; i++) {array[i + low] = tmp[i];}}

· 时间复杂度:O(n*logn),不论有序或无序都是O(n*logn)

· 空间复杂度:O(n)

· 稳定性: 稳定的排序算法

http://www.dtddedu.com/news/80.html

相关文章:

  • 360 的网站链接怎么做如何查询域名注册人信息
  • 邵阳市网站建设广州网站优化外包
  • dns劫持网站怎么做潍坊住房公积金管理中心
  • 南充建网站的资料线上销售平台有哪些
  • 注册公司需要登录的网址优化网站哪个好
  • 企业网站建设费未付款怎样挂账网站优化推广方法
  • 珠海外贸网站建设百度账号登录个人中心
  • 网站定制开发什么意思免费网站推广软件
  • 电商网站用php做的吗今日短新闻20条
  • 济南城乡住房建设厅网站网络推广平台软件
  • 网站建设项目表百度公司排名多少
  • 盘龙网站建设公司关键词排名点击软件首页
  • 专业建设金融行业网站的公司网络营销内容
  • 怎么做免费的网站链接seo优化技巧有哪些
  • 百度搜索这个网站为什么这么差seo优化网站排名
  • 网站建设设计维片seo搜索引擎推广什么意思
  • pcb计价网站建设深圳网络营销推广专员
  • 个人网站源码php厦门网站快速排名优化
  • 酷播视频网站开发论文百度最怕哪个投诉电话
  • 广 做网站蓝光电影下载seo人才招聘
  • 开发网站如何选需要注意什么免费crm系统手机版
  • h5设计制作是什么seo排名优化怎样
  • iis7 网站用户权限关键词排名查询软件
  • 网站代做多少钱优搜云seo
  • 毕设网站建设推广普通话图片
  • 邢台集团网站建设价格淘宝运营培训班
  • 建材网站建设百度推广登陆平台
  • 赤水网站建设新东方烹饪学校学费一年多少钱
  • 现在做网站开发提高网站排名软件
  • wordpress 主题 恢复成都网站seo外包