算法相关——Java排序算法之冒泡排序(二)
0. 前言
本系列文章将介绍一些常用的排序算法。排序是一个非常常见的应用场景,也是开发岗位面试必问的一道面试题,有人说,如果一个企业招聘开发人员的题目中没有排序算法题,那说明这个企业不是一个“正规”的企业,哈哈,虽然有点戏谑,但是也从侧面证明了排序算法的重要性。
本文将介绍的是常见排序算法中的冒泡排序。
2. 冒泡排序
2.1 基本思想
冒泡排序也是一种简单的排序算法,基本思想就是通过相邻两个数的循环比较,将n个数中最大/小的数一点一点推向一端,再进行下一轮的比较,即将剩余的n-1个数中最大/小的数一点一点推向一端,以此类推,经过固定的n-1轮后使其有序。
2.2 代码实现
/*
*@author Calvin
*@blog http://blog.csdn.net/seu_calvin/article/details/55097708
*@date 2017/02/14
*/ public class Order { private int[] array;
public Order(int[] array){
this.array = array;
} public void sort() {
if(array!=null){
for(int i = 1; i < array.length; i++)
for(int j = 0; j < array.length - i; j++ ){
if(array[j] > array[j+1]){
int temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
} public void print() {
for(int i = 0; i < array.length; i++)
System.out.println(array[i]);
} public static void main(String[] args) {
int[] array = new int[]{3,1,5,9,6,5,0};
Order order = new Order(array);
order.sort();
order.print();
} }
输出结果略去了。
2.3 性能特点
在序列本身有序的情况下冒泡排序法时间复杂度为O(n),最坏的情况下时间复杂度为O(n*n)。只需要一个临时变量,因此空间复杂度为O(1)。由于进行数据交换时条件不存在等于,因此不会进行相同值数据的交换,因此冒泡排序法是稳定的。
冒泡排序法性能较差,所以很少被使用,但还是要掌握冒泡排序法的思想,如果理解了冒泡排序法的思想,那么会很容易提出一些优化它的小策略,比如增加标记位标量记录每趟排序中最后一次交换的位置,这个位置后面的元素已经不用交换了,可以以此标记位来保证部分本身有序的元素不用再重复比较。
算法相关——Java排序算法之冒泡排序(二)的更多相关文章
- 算法相关——Java排序算法之快速排序(三)
		
0. 前言 本系列文章将介绍一些常用的排序算法.排序是一个非常常见的应用场景,也是开发岗位面试必问的一道面试题,有人说,如果一个企业招聘开发人员的题目中没有排序算法题,那说明这个企业不是一个" ...
 - 算法相关——Java排序算法之希尔排序(五)
		
个子块,即{3,5},{1,0},{5,2},{9,4},{6,12},将每个子块进行插入排序(即第i位与第i+5位进行比较交换),初步排序结果为{3,0,2,4,6,5,1,5,9,12}.希尔排序 ...
 - 算法相关——Java排序算法之插入排序(四)
		
0. 前言 本系列文章将介绍一些常用的排序算法.排序是一个非常常见的应用场景,也是开发岗位面试必问的一道面试题,有人说,如果一个企业招聘开发人员的题目中没有排序算法题,那说明这个企业不是一个" ...
 - 算法相关——Java排序算法之桶排序(一)
		
(代码中对应一个数组的下标),将每个元素放入对应桶中,再将所有元素按顺序输出(代码中则按顺序将数组i下标输出arrary[i]次),即为{0,1,3,5,5,6,9}. 1.2 代码实现 /* *@ ...
 - Java排序算法(二)
		
java排序算法(二) 二.改进排序算法 2.1希尔排序 定义:希尔排序(ShellSort)是插入排序的一种.也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. ...
 - java排序算法之冒泡排序和快速排序
		
总结一下Java排序算法,以便记忆. 各类排序的时间复杂度: 排序方法 时间复杂度(平均) 时间复杂度(最坏) 时间复杂度(最好) 空间复杂度 稳定性 复杂性 直接插入排序 O(n2)O(n2) O( ...
 - java排序算法(四):冒泡排序
		
java排序算法(四):冒泡排序 冒泡排序是计算机的一种排序方法,它的时间复杂度是o(n^2),虽然不及堆排序.快速排序o(nlogn,底数为2).但是有两个优点 1.编程复杂度很低.很容易写出代码 ...
 - java排序算法(二):直接选择排序
		
java排序算法(二) 直接选择排序 直接选择排序排序的基本操作就是每一趟从待排序的数据元素中选出最小的(或最大的)一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完,它需要经过n- ...
 - java排序算法之冒泡排序(Bubble Sort)
		
java排序算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数 ...
 
随机推荐
- Android根据图片Uri获取图片path绝对路径的几种方法【转】
			
在Android 编程中经常会用到Uri转化为文件路径,如我们从相册选择图片上传至服务器,一般上传前需要对图片进行压缩,这时候就要用到图片的绝对路径. 下面对我开发中uri转path路径遇到的问题进行 ...
 - How to deploy kotlin in androidstudio?
			
Kotlin is a good language,more playable than Java.So how do we deploy kotlin? First,install the kotl ...
 - 聊聊HTTP gzip压缩与常见的Android网络框架
			
版权声明: 欢迎转载,但请保留文章原始出处 作者:GavinCT 出处:http://www.cnblogs.com/ct2011/p/5835990.html 进入主题之前,我们先来看一下客户端与服 ...
 - QQ浏览器兼容模式问题
			
今天客户反馈有个问题,他说用360浏览器的兼容模式无法登陆系统,我试了可以,接着试了IE11,也可以,然后跟经理汇报,他说他用qq浏览器兼容模式就不可以,于是我试了,果然不可以... 问题是酱紫的:输 ...
 - eclipse下载教程
			
Eclipse 是一个开放源代码的.基于 Java 的可扩展开发平台. Eclipse 是 Java 的集成开发环境(IDE),当然 Eclipse 也可以作为其他开发语言的集成开发环境,如C,C++ ...
 - Spark内存分配诊断
			
1.JVM自带众多内存诊断的工具,例如:JMap,JConsole等,第三方IBM JVM Profile Tools等. 2.日志!在开发.测试.生产环境中最合适的就是日志,特别是Driver产生的 ...
 - C#基础(数据类型运算符)
			
---恢复内容开始--- 1.类 修饰符 class 类名 基类或接口 { } 2.命名规范 成员变量前加_ 首字符小写,后面单词首字母大写(Camel规则) 接口首字母为I 方法的命名使用动词 所有 ...
 - MongoDB的安装与python操作MongoDB
			
一.安装MongoDB 因为我个人使用的是windows,就只记录下windows下的安装 1.下载安装 就是官网,下载msi,选个路径安装 2.配置 看见别的地方说需要手动在bin同级目录创建dat ...
 - 在excel中将缺失数据全部用0补齐
			
先ctrl+H ,出现如下对话框 点击“定位”,选择“空值” 在表格中空的位置上编辑栏输入0,CTRL+ENTER,即可将缺失数据全部用0补齐.
 - Python 使用 xlwings 往 excel中写入一列数据的两种方法
			
1.准备一个二维列表,然后再range后面不指定任何选项,可以输出该二维列表中数据在一列中显示,如下代码: # -*- coding:utf-8 -*- import xlwings as xw li ...