Java实现数组排序

  1. package com.souvc.hibernate.exp;
  2.  
  3. public class MySort {
  4.  
  5. /**
  6. * 方法名:main</br>
  7. * 详述:Java实现数组排序 </br>
  8. * 开发人员:liuhf </br>
  9. * 创建时间:2016-3-22 </br>
  10. * @param args
  11. * @throws
  12. * @since V1.0
  13. */
  14. public static void main(String[] args) {
  15. int array[] = {45,32,54,12,43,65,11,3,43,6,33,90,44,1,178};
  16. MySort mySort = new MySort();
  17. mySort.insertSort(array);
  18. System.out.print("插入排序结果 : ");
  19. mySort.printArray(array);
  20. System.out.println();
  21. mySort.bubbleSort(array);
  22. System.out.print("冒泡排序结果 : ");
  23. mySort.printArray(array);
  24. mySort.qsort(array);
  25. System.out.println();
  26. System.out.print("快速排序结果 : ");
  27. mySort.printArray(array);
  28. mySort.shellSort(array);
  29. System.out.println();
  30. System.out.print("希尔排序结果 : ");
  31. mySort.printArray(array);
  32. mySort.selectSort(array);
  33. System.out.println();
  34. System.out.print("选择排序结果 : ");
  35. mySort.printArray(array);
  36. }
  37.  
  38. /**
  39. * 直接插入排序
  40. * 基本思想:在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。如此反复循环,直到全部排好顺序
  41. */
  42. public void insertSort(int[] array){
  43. int temp=0;
  44. for(int i=1;i<array.length;i++){
  45. int j=i-1;
  46. temp=array[i];
  47. for(;j>=0&&temp<array[j];j--){
  48. array[j+1]=array[j]; //将大于temp的值整体后移一个单位
  49. }
  50. array[j+1]=temp;
  51. }
  52. }
  53.  
  54. /**
  55. * 冒泡排序
  56. * 基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。
  57. */
  58. public void bubbleSort(int[] array) {
  59. int temp;
  60. for(int i=0;i<array.length;i++){//趟数
  61. for(int j=0;j<array.length-i-1;j++){//比较次数
  62. if(array[j]>array[j+1]){
  63. temp=array[j];
  64. array[j]=array[j+1];
  65. array[j+1]=temp;
  66. }
  67. }
  68. }
  69. }
  70.  
  71. /**
  72. * 快速排序
  73. * 基本思想:选择一个基准元素,通常选择第一个元素或者最后一个元素,通过一趟扫描,将待排序列分成两部分,一部分比基准元素小,一部分大于等于基准元素,此时基准元素在其排好序后的正确位置,然后再用同样的方法递归地排序划分的两部分。
  74. * @param array
  75. */
  76. public void qsort(int array[]){
  77. if(array.length>1){
  78. _qsort(array,0,array.length-1);
  79. }
  80. }
  81. /**
  82. * 一趟快速排序
  83. * @param array
  84. */
  85. private void _qsort(int[] array,int low,int high){
  86. if(low < high){
  87. int middle = getMiddle(array, low, high);
  88. _qsort(array,low,middle-1);
  89. _qsort(array, middle+1, high);
  90. }
  91. }
  92. /**
  93. * 得到中间值
  94. */
  95. private int getMiddle(int[] array,int low,int high){
  96. int tmp = array[low];
  97. while(low < high){
  98. while(low < high && array[high] >= tmp)
  99. high--;
  100. array[low] = array[high];
  101. while(low<high && array[low]<=tmp)
  102. low++;
  103. array[high] = array[low];
  104. }
  105. array[low] = tmp;
  106. return low;
  107. }
  108.  
  109. /**
  110. * 简单选择排序
  111. * 基本思想:在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。
  112. * @param array
  113. */
  114. public void selectSort(int[] array){
  115. int position=0;
  116. for(int i=0;i<array.length;i++){
  117.  
  118. int j=i+1;
  119. position=i;
  120. int temp=array[i];
  121. for(;j<array.length;j++){
  122. if(array[j]<temp){
  123. temp=array[j];
  124. position=j;
  125. }
  126. }
  127. array[position]=array[i];
  128. array[i]=temp;
  129. }
  130. }
  131.  
  132. /**
  133. * 希尔排序(最小增量排序)
  134. * 基本思想:算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。
  135. * @param array
  136. */
  137. public void shellSort(int[] array){
  138. double d1=array.length;
  139. int temp=0;
  140. while(true){
  141. d1= Math.ceil(d1/2);
  142. int d=(int) d1;
  143. for(int x=0;x<d;x++){
  144. for(int i=x+d;i<array.length;i+=d){
  145. int j=i-d;
  146. temp=array[i];
  147. for(;j>=0&&temp<array[j];j-=d){
  148. array[j+d]=array[j];
  149. }
  150. array[j+d]=temp;
  151. }
  152. }
  153. if(d==1)
  154. break;
  155. }
  156. }
  157.  
  158. /**
  159. * 打印数组中的所有元素
  160. */
  161.  
  162. public void printArray(int[] array){
  163. for (int i = 0; i < array.length; i++) {
  164. System.out.print(array[i]+" ");
  165. }
  166. }
  167. }

Java通过几种经典的算法来实现数组排序的更多相关文章

  1. 七种经典排序算法及Java实现

    排序算法稳定性表示两个值相同的元素在排序前后是否有位置变化.如果前后位置变化,则排序算法是不稳定的,否则是稳定的.稳定性的定义符合常理,两个值相同的元素无需再次交换位置,交换位置是做了一次无用功. 下 ...

  2. Java中23种经典设计模式详解

    Java中23种设计模式目录1. 设计模式 31.1 创建型模式 41.1.1 工厂方法 41.1.2 抽象工厂 61.1.3 建造者模式 101.1.4 单态模式 131.1.5 原型模式 151. ...

  3. Java实现7种常见密码算法

    原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介 前面在密码学入门一文中讲解了各种常见的密码学概念.算法与运用场景,但没有介绍过代码,因此,为作补充,这一篇将会介绍 ...

  4. Jerry 2017年的五一小长假:8种经典排序算法的ABAP实现

    2017年4月29日~5月1日,国际劳动节, 三天的小长假. 在国内,小长假往往是这样的: 然而我当时在戏称为"德村"(德国农村)的Walldorf出差并且住在Wiesloch, ...

  5. 基于python的七种经典排序算法

    参考书目:<大话数据结构> 一.排序的基本概念和分类 所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法. ...

  6. 【知了堂学习笔记】java 编写几种常见排序算法

    排序的分类: 一.交换排序 所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置,交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动. 1.冒泡 ...

  7. 基于python的七种经典排序算法(转)

    一.排序的基本概念和分类 所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法. 排序的稳定性:经过某种排序后,如果两个 ...

  8. 几种经典排序算法的R语言描述

    1.数据准备 # 测试数组 vector = c(,,,,,,,,,,,,,,) vector ## [] 2.R语言内置排序函数 在R中和排序相关的函数主要有三个:sort(),rank(),ord ...

  9. Java中几种常见排序算法

    日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数 ...

随机推荐

  1. BroadcastReceiver注册、使用及其权限

    首先声明一个类,此类继承自BroadcastReceiver类,处理Android当中发出的广播事件: public class SMSReceiver extends BroadcastReceiv ...

  2. Android之圆形头像裁切

    PS:今天项目测试组发现,百度地图定位的数据坐标位置是正确的,但是显示的数据是错误的.最后查来查去发现,那个商厦在百度地图上根本就没有那条数据,这让我如何显示,当初就推崇使用高德地图定位,上面的数据量 ...

  3. React Native at first sight

    what is React Native? 跟据官方的描述, React Native是一套使用 React 构建 Native app 的编程框架. 推出不久便引发了广泛关注, 这也得益于 Java ...

  4. WebView JS与RN进行通讯

    RN0.37终于官方增加了WebView与React Native的通讯,之前一真使用的是第三方控件React-Native-WebView-Bridge,但不是知道怎么回事这个第三方控件喊了很长时间 ...

  5. Yii2:避免文件路径暴漏,代理访问文件

    制作背景:公司要做第三方文件管理系统,客户有时候需要直接访问文件,但是我们又不想暴露文件路径,才有这代理访问 基本功能介绍:读取txt文档.读取图片,如果有需要,可以通过插件读取doc.pdf文档, ...

  6. 关于依赖注入IOC/DI的感想

    之前一直不明白依赖注入有什么好处,甚至觉得它是鸡肋,现在想想,当时真是可笑. 这个想法正如同说接口是没有用处一样. 当整个项目非常庞大,各个方法之间的调用非常复杂,那么,可以想象一下,假设说没有任何的 ...

  7. LZW压缩算法——简明原理与实现

    LZW和哈夫曼编码一样,是无损压缩中的一种.该算法通过建立字典,实现字符重用与编码,适用于source中重复率很高的文本压缩.本文首先讲下LZW的编解码原理,然后给出LZW的实现code. ***** ...

  8. 自定义JsonResult解决 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用

    接上篇的问题,给出我自己的解决方案. 同时推荐要学习MVC的可以参考下<ASP.NET MVC4 框架揭秘>. 首先,要自定义JSonResult,就要明白MVC中 JsonResult的 ...

  9. 3D banner(CSS3+HTML5)

    1.这是一篇 3Dbanner制作的简易流程,支持高版本的chrome和firefox浏览器,俩浏览器显示可能会有些差异 2.没有兼容性代码,因为仅仅只是熟悉流程,希望小伙伴们自己改善哈(>﹏& ...

  10. OC笔记一:Objective-C简介

    1.OC简介 全称:Objective-C,是扩充C的面向对象编程语言,主要用于iOS和Mac OS开发. C语言的基础上,增加了一层最小的面向对象语法 完全兼容C语言 可以在OC代码中混入C语言代码 ...