排序算法

排序算法中包括:简单排序、高级排序

简单排序

简单排序常用的有:冒泡排序、选择排序、插入排序

  • 冒泡排序代码如下:
 private static void bubbleSrot(int[] arr) {

 for (int i = 0; i < arr.length - 1; i++) {

 for (int j = i + 1; j < arr.length; j++) {

 if (arr[i] > arr[j]) {

 int temp = arr[i];

 arr[i] = arr[j];

 arr[j] = temp;

 }

 }

 }

 }

  冒泡排序方法速度是很慢的,运行时间为O(N²)级。选择排序改进了冒泡排序,将必要的交换次数从O(N²)减少到O(N),不幸的是比较次数依然是O(N²)级。然而,选择排序依然为大记录量的排序提出了一个非常重要的改进,因为这些大量的记录需要在内存中移动,这就使交换的时间和比较的时间相比起来,交换的时间更为重要。
---------------------

  • 选择排序代码如下:
 private static void chooseSort(int[] arr) {

 for (int i = 0; i < arr.length; i++) {

 int least = i;

 for (int j = i + 1; j < arr.length; j++) {

 if (arr[j] < arr[least]) {

 least = j;

 }

 }

 // 将当前第一个元素与它后面序列中的最小的一个 元素交换,也就是将最小的元素放在最前端

 int temp = arr[i];

 arr[i] = arr[least];

 arr[least] = temp;

 }

 }

  选择排序的效率:选择排序和冒泡排序执行了相同次数的比较:N*(N-1)/2。对于10个数据项,需要45次比较,然而,10个数据项只需要少于10次的交换。对于100个数据项,需要4950次比较,但只进行不到100次交换。N值很大时,比较的次数是主要的,所以结论是选择排序和冒泡哦排序一样运行了O(N²)时间。但是,选择排序无疑更快,因为它进行的交换少得多。
---------------------

  • 插入排序代码如下:
 private static void insertionSort(int[] arr) {

 int in, out;

 for (out = 1; out < arr.length; out++) {

 int temp = arr[out];

 in = out;

 while (in > 0 && arr[in - 1] >= temp) {

 arr[in] = arr[in - 1];

 --in;

 }

 arr[in] = temp;

 }

 }

  插入排序的效率:这个算法中,第一趟排序,最多比较一次,第二趟排序,最多比较两次,以此类推,最后一趟最多比较N-1次,因此有1+2+3+…+N-1 = N*(N-1)/2。然而,因为在每一趟排序发现插入点之前,平均只有全体数据项的一半真的进行了比较,所以除以2最后是N*(N-1)/4。
对于随机顺序的数据,插入排序也需要O(N²)的时间级。当数据基本有序,插入排序几乎只需要O(N)的时间,这对把一个基本有序的文件进行排序是一个简单而有效的方法。
  对于逆序排列的数据,每次比较和移动都会执行,所以插入排序不比冒泡排序快。
---------------------

  • 归并排序

 // 将两个已排序的数组合并到第三个数组上。

 private static void merge(int[] arrA, int[] arrB, int[] arrC) {

 int aDex = 0, bDex = 0, cDex = 0;

 int sizeA = arrA.length;

 int sizeB = arrB.length;

 // A数组和B数组都不为空

 while (aDex < sizeA && bDex < sizeB) {

 if (arrA[aDex] < arrB[bDex]) {

 arrC[cDex++] = arrA[aDex++];

 } else {

 arrC[cDex++] = arrB[bDex++];

 }

 }

 // A数组不为空,B数组为空

 while (aDex < sizeA) {

 arrC[cDex++] = arrA[aDex++];

 }

 // A数组为空,B数组不为空

 while (bDex < sizeB) {

 arrC[cDex++] = arrB[bDex++];

 }

 }

高级排序

  常见的高级排序:哈希排序、快速排序,这两种排序算法都比简单排序算法快得多:希尔排序大约需要O(N*(logN)²)时间,快速排序需要O(N*logN)时间。这两种排序算法都和归并排序不同,不需要大量的辅助存储空间。希尔排序几乎和归并排序一样容易实现,而快速排序是所有通用排序算法中最快的一种排序算法。 还有一种基数排序,是一种不常用但很有趣的排序算法。

  • 哈希排序

  哈希排序是基于插入排序的,实现代码如下:

 private static void shellSort(int[] arr) {

 int inner, outer;

 int temp;

 int h = 1;

 int nElem = arr.length;

 while (h <= nElem / 3) {

 h = h * 3 + 1;

 }

 while (h > 0) {

 for (outer = h; outer < nElem; outer++) {

 temp = arr[outer];

 inner = outer;

 while (inner > h - 1 && arr[inner - h] >= temp) {

 arr[inner] = arr[inner - h];

 inner -= h;

 }

 arr[inner] = temp;

 }

 h = (h - 1) / 3;

 }

 }
---------------------
  • 快速排序

  快速排序是最流行的排序算法,在大多数情况下,快速排序都是最快的,执行时间是O(N*logN)级,划分是快速排序的根本机制。划分本身也是一个有用的操作。 划分数据就是把数据分为两组,使所有关键字大于特定值的数据项在一组,所有关键字小于特定值的数据项在另一组。代码实现如下:

 // 快速排序

 private static void recQuickSort(int arr[], int left, int right) {

 if (right - left <= 0) {

 return;

 } else {

 int pivot = arr[right];// 一般使用数组最右边的元素作为枢纽

 int partition = partitionIt(arr, left, right, pivot);

 recQuickSort(arr, left, partition - 1);

 recQuickSort(arr, partition + 1, right);

 }

 }

 // 划分

 private static int partitionIt(int[] arr, int left, int right, int pivot) {

 int leftPtr = left - 1;

 // int rightPtr = right + 1;

 int rightPtr = right; // 使用最右边的元素作为枢纽,划分时就要将最右端的数据项排除在外

 while (true) {

 while (arr[++leftPtr] < pivot)

 ;

 while (rightPtr > 0 && arr[--rightPtr] > pivot)

 ;

 if (leftPtr >= rightPtr) {

 break;

 } else {

 // 交换leftPtr和rightPtr位置的元素

 int temp = arr[leftPtr];

 arr[leftPtr] = arr[rightPtr];

 arr[rightPtr] = temp;

 }

 }

 // 交换leftPtr和right位置的元素

 int temp = arr[leftPtr];

 arr[leftPtr] = arr[right];

 arr[right] = temp;

 return leftPtr;// 返回枢纽位置

 }
---------------------

查找算法

对于有序的数组,常用的查找算法:二分查找。代码如下:

 private static int find(int [] arr,int searchKey){

         int lowerBound = 0;

         int upperBound = arr.length -1;

         int curIn;

         while(lowerBound <= upperBound){

             curIn = (lowerBound + upperBound) / 2;

             if(arr[curIn] == searchKey){

                 return curIn;

             }else{

                 if(arr[curIn] < searchKey){

                     lowerBound = curIn + 1;

                 }else{

                     upperBound = curIn - 1;

                 }

             }

         }

         return -1;

     }
---------------------

java开发过程中几种常用算法的更多相关文章

  1. Java中几种常用数据类型之间转换的方法

    Java中几种常用的数据类型之间转换方法: 1. short-->int 转换 exp: short shortvar=0; int intvar=0; shortvar= (short) in ...

  2. 【Java基础】Java开发过程中的常用工具类库

    目录 Java开发过程中的常用工具类库 1. Apache Commons类库 2. Guava类库 3. Spring中的常用工具类 4. 其他工具 参考 Java开发过程中的常用工具类库 1. A ...

  3. javascript中数组的常用算法深入分析

    Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...

  4. Java集合中迭代器的常用用法

    该例子展示了一个Java集合中迭代器的常用用法public class LinkedListTest { public static void main(String[] args) { List&l ...

  5. android(java) 开发过程中经验及总结记录

    android(java) 开发过程中经验及总结记录

  6. Java开发中的eclispe常用快捷键&全部快捷键

    Java开发中的eclispe常用快捷键&全部快捷键 Ctrl+1 快速修复(经典快捷键)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ ...

  7. java 中几种常用数据结构

    Java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类. 一.几个常用类的区别 1.A ...

  8. 用 Java 实现的八种常用排序算法

    八种排序算法可以按照如图分类 交换排序 所谓交换,就是序列中任意两个元素进行比较,根据比较结果来交换各自在序列中的位置,以此达到排序的目的. 1. 冒泡排序 冒泡排序是一种简单的交换排序算法,以升序排 ...

  9. java面向对象中的String类中12种常用的方法

    1.字符串与字符数组的转换 字符串可以使用toCharArray()方法变成一个字符数组,也可以使用String类的构造方法把一个字符数组变成一个字符串. public class StringAPI ...

随机推荐

  1. 【摘录】JAVA内存管理-自动选择垃圾收集器算法

    在J2SE 5.0,垃圾收集的默认值:垃圾收集器.堆大小以及JVM的类型(客户端还是服务器)都会根据应用运行的硬件平台和操作系统自动选择.相比之前设置命令行参数的方式,自动选择很好的匹配了不同类型的应 ...

  2. luogu p1003

    P1003 题意 经过多个矩形(1e3)覆盖后后某个坐标属于那个矩形(仅仅是一次询问) 大水题,直接的做法,从后向前处理矩形是否覆盖查询的点,若覆盖,则是该矩形编号 题解 int get_num(){ ...

  3. Vue.mixin Vue.extend(Vue.component)的原理与区别

    1.本文将讲述 方法 Vue.extend Vue.mixin 与 new Vue({mixins:[], extend:{}})的区别与原理 先回顾一下 Vue.mixin 官网如下描述: Vue. ...

  4. Python数学实现二元一次方程

    import cmath import math import sys def get_float(msg,allow_zero): x = None while x is None: try: x ...

  5. spring mvc 下载

    1.代码: response.setContentType("application/msword;charset=GBK"); try { response.setHeader( ...

  6. 【Codeforces Round #476 (Div. 2) [Thanks, Telegram!] B】Battleship

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 暴力枚举船的左上角. 然后统计每个点被覆盖次数就好. [代码] #include <bits/stdc++.h> #de ...

  7. ORDER BY排序子句

    10.ORDER BY排序子句   用于指定将查询结果排序的字段.     //查询emp表所有记录,结果按ename升序排列   select empno,ename   from emp   or ...

  8. 应用Spring和Hibernate(C3P0数据池)写数据库交互项目

    一.xml的配置文件(application.xml) <?xml version="1.0" encoding="UTF-8"?> <bea ...

  9. Java知识点解析

    JAVA 1:简述Java的基本历史 java起源于SUN公司的一个GREEN的项目,其原先目的是为家用消费电子产品 发送一个信息的分布式代码系统,通过发送信息控制电视机.冰箱等. 2:简单写出Jav ...

  10. 英语影视台词---七、THE GREAT GATSBY QUOTES

    英语影视台词---七.THE GREAT GATSBY QUOTES 一.总结 一句话总结:了不起的盖茨比 1.“So we beat on, boats against the current, b ...