Java 冒泡排序

冒泡排序–时间复杂度n^2

  • 对数组序列从前向后依次比较相邻两个元素的大小,若逆序则两个元素交换位置
  • 如果一趟下来没有发生交换,则说明序列有序,可以在序列中设置一个标志flag判断元素是否发生交换,从而来减少不必要的比较(在写完排序算法后再写)
  • 小结:
  • 一共进行数组大小-1次的外部循环
  • 每一趟排序的次数在逐渐地减少
  • 在一趟排序中,没有发生一次交换,则可以提前结束冒泡排序
  • 第一趟排序,将最大的数排在最后,第2趟把第二大的数排在倒数第二个
    演变过程:
int arr[]={3,9,-1,10,-2};1次排序结果[3, -1, 9, -2, 10]2次排序结果[-1, 3, -2, 9, 10]3次排序结果[-1, -2, 3, 9, 10]4次排序结果[-2, -1, 3, 9, 10]

代码实现:

import java.util.Arrays;
public class BubbleSort {public static void main(String[] args) {int arr[] = {3, 9, -1, 10, -2};//第一趟排序,将最大的数排在最后int temp = 0;//临时变量//外部循环控制整个的循环次数for (int i = 0; i < arr.length - 1; i++) {//控制相邻元素的交换次数for (int j = 0; j < arr.length - 1 - i; j++) {//如果前面的数比后面的数大则交换if (arr[j] > arr[j + 1]) {temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}System.out.println("第" + (i+1) + "次排序结果" + Arrays.toString(arr));}}
}

优化:在排序循环完成之前就已经有序了,使用标志flag
优化之前:

 int arr[] = {3, 9, -1, 10, 20};1次排序结果[3, -1, 9, 10, 20]2次排序结果[-1, 3, 9, 10, 20]3次排序结果[-1, 3, 9, 10, 20]4次排序结果[-1, 3, 9, 10, 20]

优化之后:

 int arr[] = {3, 9, -1, 10, 20};1次排序结果[3, -1, 9, 10, 20]2次排序结果[-1, 3, 9, 10, 20]

实现代码:
在每一次排序完后,进行判断是否有过交换

import java.util.Arrays;public class BubbleSort {public static void main(String[] args) {int arr[] = {3, 9, -1, 10, 20};boolean flag = false;//标志变量,表示是否进行过交换//第一趟排序,将最大的数排在最后int temp = 0;//临时变量//外部循环控制整个的循环次数for (int i = 0; i < arr.length - 1; i++) {//控制相邻元素的交换次数for (int j = 0; j < arr.length - 1 - i; j++) {//如果前面的数比后面的数大则交换if (arr[j] > arr[j + 1]) {flag=true;//交换过temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}if (!flag){//在一趟排序中,一次交换都没有发生过break;}else {flag=false;//重置flag,进行下一次交换}System.out.println("第" + (i + 1) + "次排序结果" + Arrays.toString(arr));}}
}

时间测试:

实现思路:

 //测试时间Date date2 = new Date();//格式化时间SimpleDateFormat simpleDateFormat2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateStr2 = simpleDateFormat2.format(date2);System.out.println("排序后的时间: " + dateStr2);
排序前的时间: 2020-12-09 16:43:12
排序后的时间: 2020-12-09 16:43:22

代码实现:

import java.text.SimpleDateFormat;
import java.util.Date;public class BubbleSort {public static void main(String[] args) {int arr[] = new int[80000];for (int i = 0; i < 80000; i++) {arr[i] = (int) (Math.random() * 80000);//生成[0,80000)的随机数}//测试时间Date date1 = new Date();//格式化时间SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateStr = simpleDateFormat.format(date1);System.out.println("排序前的时间: " + dateStr);boolean flag = false;//标志变量,表示是否进行过交换//第一趟排序,将最大的数排在最后int temp = 0;//临时变量//外部循环控制整个的循环次数for (int i = 0; i < arr.length - 1; i++) {//控制相邻元素的交换次数for (int j = 0; j < arr.length - 1 - i; j++) {//如果前面的数比后面的数大则交换if (arr[j] > arr[j + 1]) {flag = true;//交换过temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}if (!flag) {//在一趟排序中,一次交换都没有发生过break;} else {flag = false;//重置flag,进行下一次交换}}//测试时间Date date2 = new Date();//格式化时间SimpleDateFormat simpleDateFormat2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String dateStr2 = simpleDateFormat2.format(date2);System.out.println("排序后的时间: " + dateStr2);}
}

参考B站尚硅谷视频–冒泡排序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/446916.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用openssl开源AES算法,实现aes、aes-cbc和aes-ecb对字符串的加解密

注意事项 对于用户输入的密码进行了md5运算&#xff0c;从而保证数据格式的统一性 内部调用的随机函数&#xff0c;参考我的其他博文 参考链接 头文件crypto_util.h #pragma once#include <string>namespace hsm{namespace mgmt{void get_md5_digest(const std::strin…

Android学习指南

目录核心分析内容1、学什么1.1、Android基础 & 常用1.2、Android进阶1.3、与时俱进、热门技术1.4、编程语言&#xff1a;Java与Java虚拟机1.5、计算机基础1.6、总结2、怎么学2.1、学习路径&#xff1a;如何循序渐进、阶段性的学习Android的理论知识&#xff1f;2.2、获取途…

使用memcmp函数判断两个函数的前n位字节数是否相等

memcmp函数的介绍 头文件&#xff1a;#include <string.h>定义函数&#xff1a;int memcmp (const void *s1, const void *s2, size_t n);函数说明&#xff1a;memcmp()用来比较s1 和s2 所指的内存区间前n 个字符。字符串大小的比较是以ASCII 码表上的顺序来决定&#x…

java 选择排序

选择排序–时间复杂度n^2 第一次从arr[0]–arr[n-1]中选出最小值,与arr[0]交换 第二次从arr[1]–arr[n-1]中选出最小值,与arr[1]交换… 最小数:假定当前这个数是最小数,然后和后面的每个数进行比较,当发现有更小的数时,重定最小数与最小数的下标 总结: 选择排序一共有数组大…

Linux环境下实现unsigned char*向string的转换

代码 unsigned char input_data[input_data_length] {"This is my first encrypted plaintext hello world"}; openssl_enc_string hsm::mgmt::aes_ecb_encrypt_to_string(static_cast<string>((const char * )input_data),password);使用static_cast<st…

概率论 事件关系 古典概型与几何概型

基本知识点 随机试验:1.不确定性2.可预知性3.可重复性基本事件:包含一个样本点 必然事件:全集 不可能事件:空集 子集2^n-1-1(减去空集与真集) 事件间的关系 1.包含关系 2.和运算AUBAB,A与B至少有一个发生 3.积事件A∩BAB,AB同时发生 4.差事件A-BAB ̅A-AB,A发生但B不发生 5.…

Android代码命名规范

目录目录1、为什么 规范 Android 代码命名&#xff1f;2、Android需要命名的代码&#xff08;对象&#xff09;有哪些&#xff1f;3、具体命名规范3.1、包3.2、类3.3、变量3.4、方法3.5、参数名3.6、资源3.6.1、布局文件资源3.6.2、图片资源3.6.3、参数值资源3.6.4、动画资源3.…

安卓牛客专项练习2020.12.10

安卓Activity活动 Android的Activity活动中&#xff0c;我们一般可以归结为四种状态: 1.运行状态Running 2.暂停状态Paused 3.停止状态Stopped 4.销毁状态Destroyed 动画Animation 1.补间动画TWeen Animation 其中包括: 平移Translate Animation 透明Alpha Animation 旋转Ro…

将结构体数据存储到一段字符串string中

核心思想 指定一段内存空间存储结构体数据&#xff0c;然后使用一个指针强制类型转化为结构体类型的&#xff0c;就可以使用这个指针操作结构体相关的成员函数和变量结构体内存只会为定义的变量进行分配内存空间&#xff0c;函数只进行调用&#xff0c;不占据空间 结构体 void…

Idea中搭建Resin运行环境(Mac)

一、背景 idea中搭建Resin运行环境&#xff0c;可以在idea中通过点击Run按钮直接调试应用。 二、Resin下载地址 下载地址&#xff1a;https://caucho.com/products/resin/download/gpl#download 我下载的是tar.gz的&#xff0c;通过tar -zxvf命令解压到自己mac的任意目录下…

Java牛客专项练习2020.12.10

TreeSet subset()方法: subset(from,true,to,true),返回从from元素到to元素的一个集合,true判断是否包含边境元素 Java与C Java与C都有三个特征: 封装,继承,多态 抽象类与接口 1.抽象类可以有构造方法,但不能new;接口没有构造方法 2.抽象类中可以有普通成员变量int x等,接…

Idea中搭建Wildfly(JBoss)运行环境(Mac)

目录一、简介二、下载Wildfly&#xff08;JBoss&#xff09;三、配置Idea四、调试一、简介 首先说一下在linux环境&#xff0c;只需要将war包上传到 wildfly-8.2.0.Final/standalone/deployments 目录&#xff0c;然后到 wildfly-8.2.0.Final/bin 目录下 ./standalone.sh&…

启动linux的rpc服务的命令

命令 sudo service rc-local status

java插入排序

插入排序 思路: 把集合分成有序表与无序表,最开始有序表只有一个元素,无序表有n-1个元素,排序过程中每次取出无序表的第一个元素,然后与有序表中的元素比较,插入到适当位置 小结: 1.一共要进行n-1次排序循环 排序过程 排序前--- [101, 34, 119, 1] 第1轮插入后--- [34, 101,…

一个简单JavaAgent的实现

一、什么是javaagent javaagent是一个JVM“插件”&#xff0c;一种专门精心制作的.jar文件&#xff0c;它能够利用JVM提供的Instrumentation API。 1.1、概要 Java Agent由三部分组成&#xff1a;代理类、代理类元信息和JVM加载.jar和代理的机制&#xff0c;整体内容如下图所…

Openai的openai新版本调用方式

最近大家有没有发现Openai的openai已经更新到1.6.1了,而且API的调用方式发生了巨大的变化,下面来看看openai新的调用方式吧。 欢迎关注公众号 module ‘openai’ has no attribute ChatCompletion. 提示openai的版本过低。(pip install -U openai) 1. Chat API from openai…

计算机系统基础 计算机系统的基本组成与基本功能

基础知识点 1.1946年第一台通用电子计算机ENIAC诞生 2.冯.诺依曼结构: 组成:输入设备,输出设备,存储器,运算器,控制器 3.现代计算机结构模型: 组成 CPU中央处理器 PC程序计数器 IR指令寄存器 ALU算数逻辑部件 GPRs通用寄存器组 MAR存储器地址寄存器 MDR存储器数据寄存器 知…

Android UI卡顿监控

一、背景 应用的使用流畅度&#xff0c;是衡量用户体验的重要标准之一。Android 由于机型配置和系统的不同&#xff0c;项目复杂App场景丰富&#xff0c;代码多人参与迭代历史较久&#xff0c;代码可能会存在很多UI线程耗时的操作&#xff0c;实际测试时候也会偶尔发现某些业务…

linux查看内核版本信息

使用命令 uname -acat /proc/version