【知了堂学习笔记】java 编写几种常见排序算法
排序的分类:
一.交换排序
所谓交换,就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置,交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。
1.冒泡排序
算法原理
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
java代码的实现:
- package Sort;
- import java.util.Scanner;
- public class BubbleSort {
- /**
- * 冒泡排序算法的运作如下:
- 1.比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
- 3.针对所有的元素重复以上的步骤,除了最后一个。
- 4.持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较.
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- int[] arr = {78,68,48,39,95,48,94,73};
- for(int i=0;i<arr.length;i++){//实现多次全部交换
- for(int j=0;j<arr.length-1;j++){//实现一次所有交换,且每次都将选出最大的数字放在最后
- if(arr[j]>arr[j+1]){
- arr[j]=arr[j]^arr[j+1];
- arr[j+1]=arr[j]^arr[j+1];
- arr[j]=arr[j]^arr[j+1];
- }
- }
- for(int m=0;m<arr.length;m++){//输出每次交换后的数组
- System.out.print(arr[m]+" ");
- }
- System.out.println();
- }
- for(int num:arr){//输出最后一次交换完成的数组
- System.out.print(num+" ");
- }
- }
- }
2.快速排序:
算法原理
快速排序(Quicksort)是对冒泡排序的一种改进。
1设置两个变量i、j,排序开始的时候:i=0,j=arr.length-1;
2以第一个数组元素作为关键数据,赋值给key,即key=A[0];
3从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于key的值A[j],将A[j]和A[i]互换;
4从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于key的A[i],将A[i]和A[j]互换;
5重复第3、4步,直到i<j不成立。
java代码的实现:
- package Sort;
- public class QuickSort {
- /**
- * 1)设置两个变量i、j,排序开始的时候:i=0,j=arr.length-1;
- * 2)以第一个数组元素作为关键数据,赋值给,temp即=A[0];
- * 3)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于key的值arr[j],将arr[j]和arr[i]互换;
- * 4)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于key的arr[i],将arr[i]和arr[j]互换;
- * 5)重复第3、4步,直到i<j不成立。
- *
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- int[] arr = { 78, 68, 48, 39, 95, 48, 94, 73 };
- sort(arr, 0, arr.length - 1);
- for (int m = 0; m < arr.length; m++) {
- System.out.print(arr[m]+" ");
- }
- }
- public static void sort(int[] arr, int a, int b) {
- int i=a,j=b;//将a,b的值赋给i,j目的是保留a,b。
- int temp = arr[i];//获取关键数据
- while (i < j) {
- while (i < j && arr[j] >= temp) {//当后面的数字比关键数字大的时候位置不交换,
- //执行j--然后arr【j】前面的数字与temp比较
- j--;
- }
- while (arr[j] < temp) {//当后面的数字比关键数字小的时候位置交换。
- arr[i] = arr[j] ^ arr[i];
- arr[j] = arr[j] ^ arr[i];
- arr[i] = arr[j] ^ arr[i];
- }
- //当位置交换后比较的数据也从后到前,变为从前到后
- while (i < j && arr[i] <= temp) {//当前面的数字比关键数字小的时候位置不交换,
- //执行i++然后arr【i】后面的数字与temp比较
- i++;
- }
- while (arr[i] > temp) {//当前面的数字比关键数字小的时候位置交换。
- arr[j] = arr[j] ^ arr[i];
- arr[i] = arr[j] ^ arr[i];
- arr[j] = arr[j] ^ arr[i];
- }
- }
- //第一轮选则出来后获取到当前i的值由i出将数组分为两段,前后各自重复执行sort()方法,直到i<j不成立。递归的调用
- if (i > a) {//前面部分
- sort(arr, a, i - 1);
- }
- if (j < b) {//后面部分
- sort(arr, j + 1, b);
- }
- }
- }
未完待续.....
http://www.zhiliaotang.com 请关注知了堂,在这里将会有更多学习伙伴一起共同进步.。
【知了堂学习笔记】java 编写几种常见排序算法的更多相关文章
- 【知了堂学习笔记】java 编写几种常见排序算法2
排序的分类: 1.直接选择排序 它的基本思想是:第一次从R[0]~R[n-1]中选取最小值,与R[0]交换,第二次从R[1]~R[n-1]中选取最小值,与R[1]交换,....,第i次从R[i-1]~ ...
- 【知了堂学习笔记】java 编写几种常见排序算法3
排序的分类: 1.希尔排序 希尔排序是快速插入排序的改进版,希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰 ...
- [知了堂学习笔记]_ajax的两种使用方式
一.Ajax概述 1.什么是同步,什么是异步 同步现象:客户端发送请求到服务器端,当服务器返回响应之前,客户端都处于等待 卡死状态 异步现象:客户端发送请求到服务器端,无论服务器是否返回响应,客户端都 ...
- Java中几种常见排序算法
日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数 ...
- Java的几种常见排序算法
一.所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法.排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面. ...
- JavaScript版几种常见排序算法
今天发现一篇文章讲“JavaScript版几种常见排序算法”,看着不错,推荐一下原文:http://www.w3cfuns.com/blog-5456021-5404137.html 算法描述: * ...
- 【知了堂学习笔记】java 自定义异常
java 常见异常种类(Java Exception): 算术异常类:ArithmeticExecption 空指针异常类:NullPointerException 类型强制转换异常:ClassCas ...
- 【知了堂学习笔记】java 接口与抽象类
本次主角:抽象类 .接口. 对于皮皮潇这样一类的Java初学者来说,接口和抽象类如果不去花大量的精力与时间是很难弄清楚的,而我也是在最近这周的项目学习中感觉到了我对这两个概念不熟悉,所以导致对一些问题 ...
- 【知了堂学习笔记】java 底层容易忽略的知识点
1. java中的关键字 提到关键字,最主要的就是不能用关键字作为标识符,值得注意的有以下几点. ①其中goto与const在java中没有定义,但是也是关键字.这个基本用不到,但是应该有个认知. ② ...
随机推荐
- 转【Zabbix性能调优:配置优化】
转载:https://sre.ink/zabbix-turn-conf/ #通过日志可以分析当前服务状态.LogFile=/tmp/zabbix_server.log #日志文件路径.LogFileS ...
- 一、Kafka初认识
一.kafka使用背景 1.Kafka使用背景 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到这样的一些问题: 我们想分析下用户行为(pageviews),以便我们设计出更好的广告位 我 ...
- java类的定义
- 装好Linux后没有声音的看过来
现代的Linux发行版对声卡的支持都应该没有问题.系统装好,声卡就应该正常工作. (尤其是ArchLinux,我觉得对硬件支持最跟得上时代步伐.) 可是我用mplayer播放mp3文件却没有声音,但也 ...
- 51nod1450 闯关游戏
题目来源: TopCoder 基准时间限制:1 秒 空间限制:131072 KB 分值: 320 一个游戏App由N个小游戏(关卡)构成,将其标记为0,1,2,..N-1.这些小游戏没有相互制约的性质 ...
- 【BZOJ】4259: 残缺的字符串 FFT
[题意]给定长度为m的匹配串B和长度为n的模板串A,求B在A中出现多少次.字符串仅由小写字母和通配符" * "组成,其中通配符可以充当任意一个字符.n<=3*10^5. [算 ...
- for-in 和 for
本文地址:http://www.cnblogs.com/veinyin/p/8745845.html 1 for for ( var i = 0 ; i < len ; i++ ) for 是 ...
- 基本控件文档-UIScrollView
CHENYILONG 基本控件文档-UIScrollView Fullscreen 基本使用作用UIScrollView可 ...
- 【leetcode 简单】 第七十四题 缺失数字
给定一个包含 0, 1, 2, ..., n 中 n 个数的序列,找出 0 .. n 中没有出现在序列中的那个数. 示例 1: 输入: [3,0,1] 输出: 2 示例 2: 输入: [9,6,4,2 ...
- 天梯赛 L2-022. (数组模拟链表) 重排链表
题目链接 题目描述 给定一个单链表 L1→L2→...→Ln-1→Ln,请编写程序将链表重新排列为 Ln→L1→Ln-1→L2→....例如:给定L为1→2→3→4→5→6,则输出应该为6→1→5→2 ...