排序从大体上来讲,做了两件事情:

1、比較两个数据项;

2、交换两个数据项。或复制当中一项

一、冒泡排序

大O表示法:交换次数和比較次数都为O(N*N)。

算法原理:

  1. 1、比較相邻的元素。假设第一个比第二个大,就交换他们两个。

  2. 2、对每一对相邻元素作相同的工作,从開始第一对到结尾的最后一对。

    在这一点。最后的元素应该会是最大的数。

  3. 3、针对全部的元素反复以上的步骤,除了最后一个。
  4. 4、持续每次对越来越少的元素反复上面的步骤,直到没有不论什么一对数字须要比較。
/**
* 冒泡排序 demo
*
*/
public void bubbleSort(){ int array [] = {22,41,22,12,93,42,23,54,77}; for (int i = 0; i < array.length-1; i++) { for (int j = 0; j < array.length-i-1; j++) { int temp = 0; if (array[j]<=array[j+1]) { }else { temp = array[j]; array[j] = array[j+1]; array[j+1] = temp; }
}
}
}

二、选择排序

选择排序改进了冒泡排序,将必要的交换次数从O(N*N)降低到O(N)次。

不幸的是比較次数仍保持为O(N*N)。然而,选择排序仍然为大记录量的排序提出了一个很重要的改进,由于这些大量的记录须要在内存中移动,这就使交换时间和比較时间比起来。交换的时间显得更为重要。

算法原理:

对照数组中前一个元素跟后一个元素的大小,假设后面的元素比前面的元素小则用一个变量k来记住他的位置,接着第二次比較。前面“后一个元素”现变成了“前一个元素”。继续跟他的“后一个元素”进行比較假设后面的元素比他要小则用变量k记住它在数组中的位置(下标)。等到循环结束的时候,我们应该找到了最小的那个数的下标了。然后进行推断,假设这个元素的下标不是第一个元素的下标。就让第一个元素跟他交换一下值。这样就找到整个数组中最小的数了。然后找到数组中第二小的数。让他跟数组中第二个元素交换一下值,以此类推。

/********************************************************
*函数名称:SelectionSort
*说明: 选择排序
*********************************************************/
void SelectionSort()
{
int array [] = {3,1,2,2,1,4,7,9,2,4,10};
int out,in,min;
for(out = 0; out < array.length - 1; out++) //从第一个位置開始
{
min = out;//确保已经排出最小数据放在最左边的情况下。从最小数据右边第一个開始比較
for (in = out + 1; in < array.length; in++) { //寻找最小的数据索引 从1開始循环
if (array[in] <= array[min]) {
min = in;
}
}
int temp = array[out];
array[out] = array[min];
array[min] = temp;
System.out.print("第"+out+"次排序:");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]+"\t");
}
System.out.println("");
}
}

  三、插入排序

在大多数情况下,插入排序算法是主要的排序算法中效率最高的一个,尽管插入排序算法仍然须要O(N*N)的时间。可是普通情况下,它要比冒泡排序快一倍,比选择排序还要快一点。

预设:局部有序

算法原理:

将n个元素的数列分为已有序和无序两个部分。例如以下所看到的:

{{a1}。{a2。a3,a4,…,an}}

{{a1⑴。a2⑴},{a3⑴,a4⑴ …,an⑴}}

{{a1(n-1),a2(n-1) ,…},{an(n-1)}}

每次处理就是将无序数列的第一个元素与有序数列的元素从后往前逐个进行比較。找出插入位置,将该元素插入到有序数列的合适位置中。

如果在一个无序的数组中,要将该数组中的数按插入排序的方法从小到大排序。如果啊a[]={3,5,2,1,4};插入排序的思想就是比大小,满足条件交换位置。一開始会像冒泡排序一样,但会比冒泡多一步就是交换后(a[i]=a[i+1]后)原位置(a[i])会继续和前面的数比較满足条件交换,直到a[i+1]前面的数组是有序的。

比方在第二次比較后数组变成a[]={2,3,5,1,4};

/**
* 插入排序
*/
public void insertSort(){ int array [] = {3,1,2}; int in,out; for (out = 1; out < array.length; out++) { int temp = array[out];//temp作为暂时变量,存储被标记的队员 in = out; while(in>0 && array[in-1] >=temp){ array[in] = array[in-1];//队员右移一位 --in; }
array[in] = temp;//插入被标记的队员 } }

四、对象排序

compareTo方法,对象排序有点须要注意。排序原理是这种,首先依据你所选属性进行排序。假设两个属性值一样,则依照下一个属性排,假设属性还是一样。则接着下一个属性往下排,依此类推。

/**
* 对象排序
*/
public void objectSort(){ Person person1 = new Person("zhang", "san", 24); Person person2 = new Person("li", "si", 21); Person person3 = new Person("wang", "wu", 28); Person [] person = {person1,person2,person3}; int in,out; for (out = 1; out < person.length; out++) { Person temp = person[out]; in = out; while(in>0 && person[in-1].getLastName().compareTo(temp.getLastName())>0){ person[in] = person[in-1]; --in; } person[in] = temp; System.out.print("第"+out+"次排序:");
for (int i = 0; i < person.length; i++) {
System.out.print(person[i].getLastName()+"\t");
}
System.out.println(""); } }
public static void main(String[] args) {
new Sort().objectSort();
}
}
class Person{ private String lastName; private String firstName; private int age; public Person(String lastName,String firstName,int age){ this.lastName = lastName; this.firstName = firstName; this.age = age; }
public String getLastName(){ return lastName;
}
}

Java数据结构与算法之排序的更多相关文章

  1. Java数据结构和算法 - 高级排序

    希尔排序 Q: 什么是希尔排序? A: 希尔排序因计算机科学家Donald L.Shell而得名,他在1959年发现了希尔排序算法. A: 希尔排序基于插入排序,但是增加了一个新的特性,大大地提高了插 ...

  2. Java数据结构和算法 - 简单排序

    Q: 冒泡排序? A: 1) 比较相邻的元素.如果第一个比第二个大,就交换它们两个; 2) 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数; 3) 针 ...

  3. java数据结构和算法------希尔排序

    package iYou.neugle.sort; public class Shell_sort { public static void ShellSort(double[] array) { i ...

  4. java数据结构和算法------选择排序

    package iYou.neugle.sort; public class Select_sort { public static void SelectSort(double[] array) { ...

  5. java数据结构和算法------合并排序

      package iYou.neugle.sort; public class Merge_sort { public static void MergeSort(double[] array, i ...

  6. Java数据结构和算法(九)——高级排序

    春晚好看吗?不存在的!!! 在Java数据结构和算法(三)——冒泡.选择.插入排序算法中我们介绍了三种简单的排序算法,它们的时间复杂度大O表示法都是O(N2),如果数据量少,我们还能忍受,但是数据量大 ...

  7. Java数据结构和算法(五)--希尔排序和快速排序

    在前面复习了三个简单排序Java数据结构和算法(三)--三大排序--冒泡.选择.插入排序,属于算法的基础,但是效率是偏低的,所以现在 学习高级排序 插入排序存在的问题: 插入排序在逻辑把数据分为两部分 ...

  8. Java数据结构和算法(三)--三大排序--冒泡、选择、插入排序

    三大排序在我们刚开始学习编程的时候就接触过,也是刚开始工作笔试会遇到的,后续也会学习希尔.快速排序,这里顺便复习一下 冒泡排序: 步骤: 1.从首位开始,比较首位和右边的索引 2.如果当前位置比右边的 ...

  9. Java数据结构和算法 - 堆

    堆的介绍 Q: 什么是堆? A: 这里的“堆”是指一种特殊的二叉树,不要和Java.C/C++等编程语言里的“堆”混淆,后者指的是程序员用new能得到的计算机内存的可用部分 A: 堆是有如下特点的二叉 ...

随机推荐

  1. PAT Basic 1045

    1045 快速排序 著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边. 给定划分后的 N 个互不相同 ...

  2. .NET:权限管理

    题外话: 临近大四,编写各种简历的时候发现,很多电子简历上是可以链上自己在各大论坛上留下的足迹.关于这点,学习网络,拥抱开源,具有互联网思维的博主很后悔,后悔当年只会在网上查资料,不会留资料,空有才能 ...

  3. Ubuntu新装系统要装软件

    1. 在虚拟机中新安装系统的时候,通常因为时间过了很长,软件有更新之后,安装vim的时候会出错,因此,装完系统先要做的: cd /var/lib/dpkg/updates/ ls sudo apt-g ...

  4. spring4 整合hibernate4时遇到的问题以及解决办法

    配置hibernate时出现了如下错误: Java.lang.NoClassDefFoundError: org/hibernate/util/DTDEntityResolver 错误原因:hiber ...

  5. Java-从字符串或一个子字符串中搜索一个字符

    indexOf函数 package com.tj; public class MyClass implements Cloneable { public static void main(String ...

  6. 纯干货!live2d动画制作简述以及踩坑

    本文来自网易云社区,转载务必请注明出处. 1. 概述 live2d是由日本Cybernoids公司开发,通过扭曲像素位置营造伪3d空间感的二维动画软件.官网下载安装包直接安装可以得到两种软件,分别是C ...

  7. 解决win7下pycharm移动文件出现Clear Read-Only status移动失败的问题

    问题描述: 将pycharm中的文件move到指定文件夹或者将其他文件拖动到pycharm指定文件夹下,会出现如下问题导致文件移动失败: 出现这个问题的原因及解决办法如下: 第一种,pycharm下建 ...

  8. SQL Server数据库和MySQL数据库有什么区别?

    SQL Server数据库和MySQL数据库有什么区别呢?详细很多初入IT行业的朋友对于SQL Server数据库和MySQL数据库经常搞混,认为这两种数据库是同一种,其实不然,今天我们来分析一下这两 ...

  9. Debian7配置LAMP(Apache/MySQL/PHP)环境及搭建建站

    完整Debian7配置LAMP(Apache/MySQL/PHP)环境及搭建建站 第一.安装和配置Apache Web服务器 运行升级命令来确保我们的系统组件各方面都是最新的. apt-get upd ...

  10. hlgoj1881

    #include <stdio.h> +]; int main(){ int l,m; int i,j; int sign; num[]=; num[]=; while(~scanf(&q ...