冒泡排序/鸡尾酒排序
冒泡排序
冒泡排序(Bubble Sort)是一种简单的排序算法,它通过多次交换相邻元素的位置来实现排序。它的基本思想是从数组的第一个元素开始,比较相邻的两个元素,如果它们的顺序错误,则交换它们的位置。重复进行这个过程,直到整个数组排序完成。
以下是冒泡排序的一种常见的Java实现:
public class BubbleSort {public static void bubbleSort(int[] array) {int n = array.length;for (int i = 0; i < n - 1; i++) {for (int j = 0; j < n - i - 1; j++) {if (array[j] > array[j + 1]) {// 交换相邻元素的位置int temp = array[j];array[j] = array[j + 1];array[j + 1] = temp;}}}}public static void main(String[] args) {int[] array = {64, 34, 25, 12, 22, 11, 90};bubbleSort(array);System.out.println("Sorted array: " + Arrays.toString(array));}
}
这段代码演示了冒泡排序算法的实现。在bubbleSort()
方法中,使用两个嵌套的循环来遍历数组并比较相邻元素的大小。如果前一个元素大于后一个元素,则进行交换。通过不断交换,较大的元素会逐渐“冒泡”到数组的末尾。外层循环控制排序的轮数,内层循环进行具体的比较和交换操作。
最后,在main()
方法中,我们创建一个示例数组并调用bubbleSort()
方法对其进行排序。然后打印出排序后的数组。
冒泡排序的时间复杂度为O(n^2),其中n是数组的大小。虽然冒泡排序在性能上不如其他高效的排序算法,但是由于其实现简单,适用于小规模的数据排序。
除了上述的常见实现外,还可以对冒泡排序进行优化,例如设置一个标志位来判断某一轮是否有元素交换,如果没有交换,则说明数组已经有序,可以提前结束排序。也可以针对特定情况进行优化,比如在已经有序的部分不再进行比较。这些优化可以减少一些不必要的比较和交换操作,提高排序效率。
public class BubbleSort {public static void bubbleSort(int[] array) {int n = array.length;boolean swapped;for (int i = 0; i < n - 1; i++) {swapped = false;for (int j = 0; j < n - i - 1; j++) {if (array[j] > array[j + 1]) {// 交换相邻元素的位置int temp = array[j];array[j] = array[j + 1];array[j + 1] = temp;swapped = true;}}// 如果某一轮没有进行元素交换,则说明数组已经有序,提前结束排序if (!swapped) {break;}}}public static void main(String[] args) {int[] array = {64, 34, 25, 12, 22, 11, 90};bubbleSort(array);System.out.println("Sorted array: " + Arrays.toString(array));}
}
在这个优化版本的冒泡排序中,我们引入了一个名为swapped
的标志位。在每一轮的比较过程中,如果有元素交换,则将swapped
设置为true
。如果某一轮没有进行元素交换,说明数组已经有序,可以提前结束排序。
通过引入标志位,可以避免在已经有序的情况下进行不必要的比较和交换操作,从而提高了冒泡排序的效率。
请注意,在最坏情况下,即输入数组完全逆序的情况下,优化后的冒泡排序的时间复杂度仍然是O(n^2)。优化的作用是在部分有序的情况下,减少了比较和交换的次数,提高了效率。
冒泡排序的多种Java实现可以根据具体的优化策略和需求进行调整和扩展,以满足特定场景下的排序需求。
鸡尾酒排序
鸡尾酒排序(Cocktail Sort),也称为双向冒泡排序(Bidirectional Bubble Sort)或定向冒泡排序(Shaker Sort),是冒泡排序的一种变体。它在排序过程中来回地在待排序序列中进行扫描和交换,以实现排序。
鸡尾酒排序的基本思想是从序列的起始位置开始,通过比较相邻元素的大小并交换它们的位置,将较大的元素逐渐“冒泡”到序列的末尾。然后,从序列的末尾开始,反向进行相同的操作,将较小的元素逐渐“冒泡”到序列的起始位置。通过来回扫描和交换的过程,逐渐缩小待排序序列的范围,直到整个序列排序完成。
以下是鸡尾酒排序的算法描述:
- 初始化两个指针
left
和right
,分别指向待排序序列的起始位置和末尾位置。 - 进行以下循环,直到
left
不再小于right
为止:- 从左到右遍历序列,比较相邻元素的大小,如果前一个元素大于后一个元素,则交换它们的位置。
- 将
right
指针向左移动一位,缩小待排序序列的范围。 - 从右到左遍历序列,比较相邻元素的大小,如果前一个元素大于后一个元素,则交换它们的位置。
- 将
left
指针向右移动一位,缩小待排序序列的范围。
- 完成排序后,序列中的元素按照从小到大的顺序排列。
以下是使用Java编写的鸡尾酒排序算法实现:
public class CocktailSort {public static void cocktailSort(int[] array) {int n = array.length;int left = 0;int right = n - 1;boolean swapped;while (left < right) {swapped = false;// 从左到右遍历,将较大的元素冒泡到末尾for (int i = left; i < right; i++) {if (array[i] > array[i + 1]) {swap(array, i, i + 1);swapped = true;}}right--;// 从右到左遍历,将较小的元素冒泡到起始位置for (int i = right; i > left; i--) {if (array[i] < array[i - 1]) {swap(array, i, i - 1);swapped = true;}}left++;// 如果某一轮没有进行元素交换,则说明数组已经有序,提前结束排序if (!swapped) {break;}}}private static void swap(int[] array, int i, int j) {int temp = array[i];array[i] = array[j];array[j] = temp;}public static void main(String[] args) {int[] array = {64, 34, 25, 12, 22, 11, 90};cocktailSort(array);System.out.println("Sorted array: " + Arrays.toString(array));}
}
在上述代码中,我们使用left
和right
两个指针来分别表示待排序序列的起始位置和末尾位置。通过不断地在序列中来回进行扫描和交换操作,可以逐渐将最大和最小的元素移动到正确的位置上。在每一轮的遍历过程中,如果没有进行元素交换,说明序列已经有序,可以提前结束排序。
请注意,鸡尾酒排序的时间复杂度也是O(n^2),其中n是数组的大小。虽然鸡尾酒排序相比于传统的冒泡排序在某些情况下能够提升效率,但它仍然是一种相对较慢的排序算法。因此,在实际应用中,如果需要排序大规模数据,通常会选择效率更高的排序算法,如快速排序或归并排序。
相关文章:
冒泡排序/鸡尾酒排序
冒泡排序 冒泡排序(Bubble Sort)是一种简单的排序算法,它通过多次交换相邻元素的位置来实现排序。它的基本思想是从数组的第一个元素开始,比较相邻的两个元素,如果它们的顺序错误,则交换它们的位置。重复进…...
代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费
代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费 309.最佳买卖股票时机含冷冻期714.买卖股票的最佳时机含手续费 309.最佳买卖股票时机含冷冻期 题目链接:309.最佳买卖股票时机含冷冻期 文章链接 状态:有…...

【Docker】Docker的使用案例以及未来发展、Docker Hub 服务、环境安全、容器部署安全
作者简介: 辭七七,目前大二,正在学习C/C,Java,Python等 作者主页: 七七的个人主页 文章收录专栏: 七七的闲谈 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖…...
qt qtabwidget获取当前选项卡的所有按键
要获取当前选项卡中的所有按键,可以通过以下步骤进行: 通过currentIndex()函数获取当前选项卡的索引。 使用widget()函数获取当前选项卡的QWidget。 连接QWidget的keyPressEvent事件,并在事件处理函数中获取按下的按键信息。 下面是示例代…...

为什么Excel插入图片不显示,点击能够显示
很久没有Excel了,今天在做Excel表格时,发现上传图片后不能显示,但是点击还是能够出现图片的 点击如下 点击能看到,但是不显示? 最后发现只需鼠标右键点击浮动即可显示...

使用Python创建faker实例生成csv大数据测试文件并导入Hive数仓
文章目录 一、Python生成数据1.1 代码说明1.2 代码参考 二、数据迁移2.1 从本机上传至服务器2.2 检查源数据格式2.3 检查大小并上传至HDFS 三、beeline建表3.1 创建测试表并导入测试数据3.2 建表显示内容 四、csv文件首行列名的处理4.1 创建新的表4.2 将旧表过滤首行插入新表 一…...

qml基础语法
文章目录 基础语法例子 属性例子 核心元素元素item RectangleText例子 Image例子 MouseArea例子Component(组件)例子简单变换例子 定位器ColumnRowGridFlowRepeater 布局InputKeys 基础语法 QML是一种用于描述对象如何相互关联的声明式语言。 QtQuick是…...

数据结构 - 2(顺序表10000字详解)
一:List 1.1 什么是List 在集合框架中,List是一个接口,继承自Collection。 Collection也是一个接口,该接口中规范了后序容器中常用的一些方法,具体如下所示: Iterable也是一个接口,Iterabl…...

05在IDEA中配置Maven的基本信息
配置Maven信息 配置Maven家目录 每次创建Project工程后都需要设置Maven家目录位置,否则IDEA将使用内置的Maven核心程序和使用默认的本地仓库位置 一般我们配置了Maven家目录后IDEA就会自动识别到conf/settings.xml配置文件和配置文件指定的本地仓库位置创建新的P…...

基于IDEA 配置Maven环境和JDK版本(全局)
1.首先启动IDEA,进去初始界面 选择 Customize 之后,选择 All settings 2. 选择下图中的列表配置 3. 找到Maven下的Runner, 配置JRE的版本,选择自己下载使用的jdk的版本即可 4.最后配置Compiler 下的 Java Compiler 选择自己的jdk版本号&am…...

mysql数据库 windows迁移至linux
1.打开navicat,选择一个数据库进行操作: 之后文件会保存为一个xxx.sql文件,之后打开xftp,把生成的sql放进一个文件夹中(/home/dell/linuxmysql): 之后登录mysql数据库,并创建一个新的数据库,然后…...
P4491 [HAOI2018] 染色
传送门:洛谷 解题思路: 写本题需要知道一个前置知识: 假设恰好选 k k k个条件的方案数为 f ( k ) f(k) f(k);先钦定选 k k k个条件,其他条件无所谓的方案数为 g ( k ) g(k) g(k) 那么存在这样的一个关系: g ( k ) ∑ i k n C i k f ( i ) g(k)\sum_{ik}^nC_{i}^kf(i) g(k)…...
12096 - The SetStack Computer (UVA)
题目链接如下: Online Judge 这道题我一开始的思路大方向其实是对的,但细节怎么实现set到int的哈希没能想清楚(没想到这都能用map)。用set<string>的做法来做,测试数据小的话答案是对的,但大数据时…...

Pygame中将鼠标形状设置为图片2-1
在Pygame中利用Sprite类的派生类将鼠标形状设置为图片,其原理就是将Sprite类的派生类对应图片的位置设置为鼠标的当前位置即可。其效果如图1所示。 图1 将鼠标设置为图片 从图1可以看出,鼠标的形状变为红色的,该红色的随着鼠标的移动而移动&…...

Vue3 + Nodejs 实战 ,文件上传项目--实现图片上传
目录 技术栈 1. 项目搭建前期工作(不算太详细) 前端 后端 2.配置基本的路由和静态页面 3.完成图片上传的页面(imageUp) 静态页面搭建 上传图片的接口 js逻辑 4.编写上传图片的接口 5.测试效果 结语 博客主页:専心_前端,javascript,mys…...

linux C++ vscode连接mysql
1.linux使用Ubuntu 2.Ubuntu安装vscode 2.1 安装的是snap版本,直接打开命令行执行 sudo snap install --classic code 3.vscode配置C 3.1 直接在扩展中搜索C安装即可 我安装了C, Chinese, code runner, 安装都是同理 4.安装mysql sudo apt update sudo apt install mysql-…...

[资源推荐]langchain、LLM相关
之前很多次逛github或者去B站看东西或者说各种浏览资讯的情况,都会先看两眼然后收藏然后就吃灰的情况,那既然这样,不如多看几眼,看看是否真的能用得上,能用在哪,然后用几句话总结出来,分享出来&…...
hdfs笔记
1.HDFS shell 1.0查看帮助 hadoop fs -help <cmd> 1.1上传 hadoop fs -put <linux上文件> <hdfs上的路径> 1.2查看文件内容 hadoop fs -cat <hdfs上的路径> 1.3查看文件列表 hadoop fs -ls / 1.4…...
java_方法引用和构造器引用
文章目录 一、方法引用1.1、方法引用的理解1.2、格式1.3、举例 二、构造器引用2.1、格式2.2、例子2.3、数组引用 一、方法引用 1.1、方法引用的理解 方法引用,可以看做是基于lambda表达式的进一步刻画当需要提供一个函数式接口的实例时,可以使用lambda…...
Flink Log4j 2.x使用Filter过滤日志类型
Flink Log4j 2.x使用Filter过滤日志类型(区别INFO、ERROR) 文章目录 Flink Log4j 2.x使用Filter过滤日志类型(区别INFO、ERROR)ThresholdFilterLevelMatchFilter 日志级别: ALL < TRACE < DEBUG < INFO < …...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...

cf2117E
原题链接:https://codeforces.com/contest/2117/problem/E 题目背景: 给定两个数组a,b,可以执行多次以下操作:选择 i (1 < i < n - 1),并设置 或,也可以在执行上述操作前执行一次删除任意 和 。求…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

Ascend NPU上适配Step-Audio模型
1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统,支持多语言对话(如 中文,英文,日语),语音情感(如 开心,悲伤)&#x…...

什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...

GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...

宇树科技,改名了!
提到国内具身智能和机器人领域的代表企业,那宇树科技(Unitree)必须名列其榜。 最近,宇树科技的一项新变动消息在业界引发了不少关注和讨论,即: 宇树向其合作伙伴发布了一封公司名称变更函称,因…...

tauri项目,如何在rust端读取电脑环境变量
如果想在前端通过调用来获取环境变量的值,可以通过标准的依赖: std::env::var(name).ok() 想在前端通过调用来获取,可以写一个command函数: #[tauri::command] pub fn get_env_var(name: String) -> Result<String, Stri…...
StarRocks 全面向量化执行引擎深度解析
StarRocks 全面向量化执行引擎深度解析 StarRocks 的向量化执行引擎是其高性能的核心设计,相比传统行式处理引擎(如MySQL),性能可提升 5-10倍。以下是分层拆解: 1. 向量化 vs 传统行式处理 维度行式处理向量化处理数…...