核心思想:

1)如有一个数列有 N(5)个元素,则至多需要 N-1(4)趟循环 才能保证数列有序

2) 每一趟循环都从数列的第一个元素开始比较,依次比较 相邻的两个元素,比较到数列的最后

3) 如果前一个元素大于后一个元素,则使用第三变量交换



基础算法的缺点:

1) 每一趟比较都要比较到数组的最后,没有必要,只要比较

到无序数列即可

for(int j=0;i<数组名.length-1;j++){
i. …..
}
i j<?
0 j<4
1 j<3
2 j<2
3 j<1
j<N-1-i;

2) 不管是否有序,都要进行 N-1 趟循环

如何判断有序?比较了一趟,没有发生交换,就是有序

定义一个 boolean 类型的变量 flag,默认有序 true;发生交

换,置为 false,一趟循环结束后,根据 flag 的值判断是否有序,有序,则退出循环

3) int temp 每次比较的时候都要给 temp 分配空间,比较完

毕后翻放空间所有的比较都使用一个 temp 变量,同一个空间,将 temp 变量提取到大循环外

完善后的代码:

int [] array1= {4,5,2,7,14,1,6};
int temp;
boolean flag;
int count=0;
System.out.println("排序前:"+Arrays.toString(array1));
// System.out.println(Arrays.binarySearch(array1, 7));
for (int i = 0; i <array1.length-1; i++) {
flag=true;
count++;
for (int j = 0; j <array1.length-1-i; j++) {
if (array1[j] > array1[j+1]) {
temp=array1[j];
array1[j]=array1[j+1];
array1[j+1]=temp;
flag=false;
}
}
if (flag) {
break;
} }
System.out.println("排序之后:"+Arrays.toString(array1));
System.out.println("循环了"+count+"次");

运行结果:



再次完善冒泡排序,这次使用键盘输入!

package com.bjsxt.Array;

import java.util.Arrays;
import java.util.Scanner; public class TestPaiXu {
public static void main(String[] args) { System.out.println("请输入一串整数,用逗号分开!");
Scanner input=new Scanner(System.in);
String str=input.next().toString();
String [] arr=str.split(",");
int temp;
boolean flag;
int count=0;
int [] array1 =new int[arr.length];
for (int i = 0; i < array1.length; i++) {
array1[i]=Integer.parseInt(arr[i]);
}
System.out.println("排序前:"+Arrays.toString(array1));
for (int i = 0; i <array1.length-1; i++) {
flag=true;
count++;
for (int j = 0; j <array1.length-1-i; j++) {
if (array1[j] > array1[j+1]) {
temp=array1[j];
array1[j]=array1[j+1];
array1[j+1]=temp;
flag=false;
}
}
if (flag) {
break;
}
}
input.close();
System.out.println("排序之后:"+Arrays.toString(array1));
System.out.println("循环了"+count+"次");
}
}

Java修炼——冒泡排序的更多相关文章

  1. [原]Java修炼 之 基础篇(二)Java语言构成

    上次的博文中Java修炼 之 基础篇(一)Java语言特性我们介绍了一下Java语言的几个特性,今天我们介绍一下Java语言的构成.        所谓的Java构成,主要是指Java运行环境的组成, ...

  2. Java版冒泡排序和选择排序

    一.理解说明 1.理解和记忆 冒泡排序:依次定位数组元素,每次只和相邻的且符合条件的元素交换位置. 选择排序:依次在数组的每个位置,通过逐个对比选择出最大或最小的元素. 2.知识点说明 (1)数组是引 ...

  3. 我JAVA修炼之路

    今天起,我会不定期更新我的java修炼之路, 2017.7.10,星期一 我参见了河南青云的培训班,这一天是我们的开班典礼. 我会不定期的总结我的学习笔记,大家喜欢的可以看看,不喜勿喷. 写代码: 1 ...

  4. Java之冒泡排序(升序)

    Java之冒泡排序 * 编辑者:鸿灬嗳 * 实现功能: 使用冒泡排序对数组:{25,24,12,76,101,96,28} 排序. */ package test05; public class Bu ...

  5. java 数组冒泡排序、转置(降序)

    1.java 数组冒泡排序 排序的基本原理(升序): 原始数据:  2 .1 .9 .0 .5 .3 .7 .6 .8: 第一次排序: 1  .2 .0 .5 .3 .7 .6 .8 .9 : 第二次 ...

  6. Java实现冒泡排序

    冒泡排序思想就是将数列的相邻两个数比较,较大的数往后保存,小的数往前. package Sort; import java.util.Arrays; public class BubbleSort { ...

  7. Java冒泡排序,Java对象冒泡排序

    今天呆公司特别无聊,百度了一下Java机试题,看到一个冒泡排序. 粘上我全部的代码: 实体类: package accp.com.internet;/** * 人物类 * @author xuxiao ...

  8. JAVA排序--[冒泡排序]

    package com.array; public class Sort_MaoPao { /** * 项目名称:冒泡排序 * 项目要求:用JAVA对数组进行排序,并运用冒泡排序算法 * 作者:Sev ...

  9. Java基础 -- 冒泡排序算法(带详细注释)

    冒泡排序的要点: 1.多轮排序,每轮排序中选出最大的元素放在最顶端,并且下次排序不再使用该元素; 2. 使用双for循环,外层for循环控制要排序的次数(轮数), 内层for循环控制当前要排序的元素并 ...

随机推荐

  1. jquery 路径动画贝塞尔动画

    jquery 路径动画贝塞尔动画 <pre><!DOCTYPE html><!DOCTYPE html><html> <head> < ...

  2. 结合参数接收响应转换原理讲解SpringBoot常用注解

    一.常用注解回顾 1.1 @RequestBody与@ResponseBody //注意并不要求@RequestBody与@ResponseBody成对使用. public @ResponseBody ...

  3. 解决vuex的数据刷新(F5)后会被初始化的问题

    介绍一个vuex的数据刷新(F5)后会被初始化的问题处理的插件:vuex-localstorage 实现的原理大概就是监听浏览器的刷新,关闭事件,把vuex的值存储到本地localstorage,刷新 ...

  4. 创建和销毁对象——用私有构造器或者枚举类型强化Singleton属性

    参考资料:<Effective Java>.<Java核心技术 卷1>.https://www.cnblogs.com/zhaosq/p/10135362.html 基础回顾 ...

  5. nyoj 773-开方数 (pow)

    773-开方数 内存限制:64MB 时间限制:1000ms 特判: No 通过数:3 提交数:8 难度:3 题目描述: 现在给你两个数 n 和 p ,让你求出 p 的开 n 次方. 输入描述: 每组数 ...

  6. 【并发编程】Java中的原子操作

    什么是原子操作 原子操作是指一个或者多个不可再分割的操作.这些操作的执行顺序不能被打乱,这些步骤也不可以被切割而只执行其中的一部分(不可中断性).举个列子: //就是一个原子操作 int i = 1; ...

  7. 总结:mysql的各种增删改查!

    (原创总结)分为数据库的增删改查,数据表(和字段)的增删改查,数据的增删改查 三部分!// 创建用户并授权 GRANT SELECT ON bodydb.user TO us@localhost ID ...

  8. vim常用命令集合(精心整理)

    vim编辑器身为一个强大的linux平台编辑器,我就不多说他强大之处了,直接来简述下常用命令,提高自己使用编辑器的效率. 然后就先说下vim编辑器的模式,有的地方说三种,有的地方说两种,教程是按照两种 ...

  9. 2018092609-2 选题 Scrum立会报告+燃尽图 01

    此作业要求参见:[https://edu.cnblogs.com/campus/nenu/2019fall/homework/8683] 一.小组情况组长:迟俊文组员:宋晓丽 梁梦瑶 韩昊 刘信鹏队名 ...

  10. Stream系列(六)Match方法使用

    条件比配 视频讲解 https://www.bilibili.com/video/av77403655/ EmployeeTestCase.java package com.example.demo; ...