java 冒泡排序 选择排序 插入排序及其异同点

2023-05-16

交换两坐标位置的swap()函数 之后要用到

public static void swap(int[] arr, int a, int b) {
		int temp;
		temp = arr[a];
		arr[a] = arr[b];
		arr[b] = temp;
	}

采用空瓶法。交换变量的三种方法 →点这里

冒泡排序

public static void bubbleSort(int[] arr) {
		for (int i = 0; i < arr.length - 1; i++) {
			for (int j = 0; j < arr.length - i - 1; j++) {
				if (arr[j] > arr[j + 1]) {
					swap(arr, j, j + 1);
				}
			}
		}
	}

将arr.length个数组中的元素按照由小到大排序:
1.从第一个元素(0号元素)开始,比较它(j)和他之后的元素(j+1)的大小并交换,将最大的元素放置在队尾。
2.重复执行1步骤(length - 1)次,每次都将剩余元素中最大的元素放置在剩余元素的队尾。
注意:
第一步执行次数为(length - 1 - j),表示“比较大小”的步骤仅发生在还没有进行过比较的剩余元素中。
外层循环(i循环)的循环次数不是数组长度,而是数组长度 - 1。因为元素两两比较大小只会发生(n - 1)次。类似五个手指头之间有四条手指缝。如果进行i次排序,程序会报错 java.lang.ArrayIndexOutOfBoundsException。

选择排序

public static void selectionSort(int[] arr) {
		int min = 0;
		int flag = -1;

		for (int i = 0; i < arr.length; i++) {
			flag = i;
			min = arr[i];
			for (int j = i; j < arr.length; j++) {
				if (arr[j] < min) {
					min = arr[j];
					flag = j;
				}
			}
			swap(arr, flag, i);
		}
	}

将arr.length个数组中的元素按照由小到大排序:
1.找出length个元素其中最小的数并放在数组的第一个位置(0号位)
2.执行length次1步骤。每次都将剩余元素中最小的数放在剩余元素的第一位。
注意:
每次将剩余元素的第一个元素设定为最小值min,如果之后遇到比第一位更小的元素,则替换最小值,记忆此元素的位置,再继续比较。
每次比较将从上一次比较完成的元素的下一位开始,到队尾结束。

插入排序:
这里提供两种写法

public static void insertSort(int[] arr) {
		for (int i = 1; i < arr.length; i++) {
			for (int j = i; j > 0 && arr[j] < arr[j - 1]; j--) {
				swap(arr, j, j - 1);
			}
		}
	}

将arr.length个数组中的元素按照由小到大排序:
插入排序的理解可以类比扑克牌的摸牌阶段(来自我的一位学长)。按照元素在数组中的顺序,先抽取第一个元素捏在手中,再抽取第二个元素即第二张牌,如果第二张牌比第一张牌小,则把第二张插入在第一张牌的前面,如果不比第一张牌小(>或=),则放在第一张牌后面;继续抽取第三张牌,与第二张进行比较,如果比第二张小,则插入在第二张牌的前面,接着比较第三张与第一张牌的大小,如果第三张比第一张小,则插入在第一张前面,如果不比第一张牌小(>或=),则停止继续向前比较;继续抽取第四张牌,依次和前一张牌比较……直到成为第一张牌或不比前一张牌小(>或=)……以此类推。
注意:
插入排序和冒泡排序的不同之处在于:插入排序只要遇到当前元素和它的前一个元素不满足交换的条件(>或<),就立即退出循环(体现在代码 && arr[j] < arr[j - 1] 的判断上),因为之前的数已经排好顺序。而冒泡排序需要两两相互验证条件,每轮挑出剩余元素中最大或最小的那一个。
第二种写法:

		public static void insertSort(int[] arr) {
			for (int i = 1; i < arr.length; i++) {
				for (int j = 0; j < i && arr[i - j] < arr[i - j - 1]; j++) {
					swap(arr, i - j, i - j - 1);
				}
			}
		}

如有错误或有更好的改进意见,欢迎批评指正!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

java 冒泡排序 选择排序 插入排序及其异同点 的相关文章

  • Docker 私有仓库

    1 Registry 官方私有仓库 xff0c 优点 xff1a 简单 xff1b 缺点 xff1a 部署无法进行复杂的管理操作 1 1 镜像 docker pull registry 2 7 1 docker pull joxit doc
  • pytorch one-hot编码

    使用scatter 将标签转换为one hot span class token keyword import span torch num class span class token operator 61 span span clas
  • python安装meshplot

    用conda或者pip直接安装如果出问题 xff0c 可以考虑使用以下方法 xff0c 从代码仓库中安装 下载代码库 span class token function git span clone https github com sko
  • python matplotlib quiver

    matplotlib中的 quiver方法可用于绘制箭头 xff08 向量 xff09 xff0c 下面介绍二维和三维中的使用方法 二维箭头向量绘制 一般参数如下 quiver span class token punctuation sp
  • 【链表】剑指offer 22. 链表中倒数最后k个结点

    题目 输入一个长度为 n 的链表 xff0c 设链表中的元素的值为 ai xff0c 输出一个链表 xff0c 该输出链表包含原链表中从倒数第 k 个结点至尾节点的全部节点 如果该链表长度小于k xff0c 请返回一个长度为 0 的链表 数
  • 【二叉树】剑指offer 54 二叉搜索树的第k个结点

    描述 给定一棵结点数为 n 二叉搜索树 xff0c 请找出其中的第 k 小的TreeNode结点 数据范围 xff1a 0 n lt 61 100
  • 【二叉树】剑指offer 77 按之字形顺序打印二叉树

    描述 给定一个二叉树 xff0c 返回该二叉树的之字形层序遍历 xff0c xff08 第一层从左向右 xff0c 下一层从右向左 xff0c 一直这样交替 xff09 输出 1 3 2 4 5 栈解法 用两个栈来存奇数层和偶数层的节点 x
  • 【二叉树】剑指offer 8 二叉树的下一个结点

    描述 给定一个二叉树其中的一个结点 xff0c 请找出中序遍历顺序的下一个结点并且返回 注意 xff0c 树中的结点不仅包含左右子结点 xff0c 同时包含指向父结点的next指针 下图为一棵有9个节点的二叉树 树中从父节点指向子节点的指针
  • 【二叉树】剑指offer 78 把二叉树打印成多行

    描述 给定一个节点数为 n 二叉树 xff0c 要求从上到下按层打印二叉树的 val 值 xff0c 同一层结点从左至右输出 xff0c 每一层输出一行 xff0c 将输出的结果存放到一个二维数组中返回 例如 xff1a 给定的二叉树是 1
  • python判断数组中是否有nan

    span class token keyword import span numpy numpy span class token punctuation span isnan span class token punctuation sp
  • ssh 免密配置

    在本机A上生成RSA密钥 ssh keygen cd ssh xff0c 看到如下文件 xff0c id rsa pub就是rsa加密算法的公钥 将本机的公钥发给对方服务器B xff0c 需要B的密码 xff0c 表示B同意被免密访问 xf
  • Docker Compose

    1 简介 Docker Compose 项目是 Docker 官方的开源项目 xff0c 负责实现对Docker容器集群的快速编排 Docker Compose将所管理的容器分为三层 xff1a 工程 xff08 project xff09
  • 【剑指offer】数组中重复的数字

    解法1 重排序法 抓住题目中的特点 xff0c 由于数组的所有数字都在0 n 1范围内 xff0c 所以数据的范围和下标的范围是一样的 线性扫描数组 xff0c 将扫描到的数放到它对应的下标位置上 若对应位置上已经有这个数则可以判断这是一个
  • 【剑指offer】删除链表的节点

    遍历链表 xff0c 判断当前节点是否为给定删除值 xff0c 是则将其删除 xff08 让该节点的父节点指向其子节点 xff09 实现时可以在链表头部加一个临时节点 xff0c 方便处理待删节点在第一个的情况 span class tok
  • 【剑指offer】栈的压入、弹出序列

    解题思路 由于出栈序列会存在很多种可能 xff0c 例如入栈顺序为1 2 3 4 5 xff0c 可能的出栈序列为1 2 3 4 5 4 5 3 2 1等等 xff0c 不可能将所有序列进行穷举 xff0c 因此需要按照入栈序列和出栈序列进
  • 【剑指offer】数字序列中某一位的数字

    解法一 如下图所示 xff0c 将字符序列按照位数分为多个区域 xff0c 蓝色区域共有10个数 xff0c 每个数一位 xff0c 占10位 xff0c 橙色区域共90个数 xff0c 每个数两位 xff0c 占180位 xff0c 以此
  • 【剑指offer】二叉搜索树的第k个节点

    利用二叉搜索树的特点 xff0c 左边节点的值 lt 中间节点的值 lt 右边节点的值 xff0c 对二叉树进行中序遍历即可 通过res保存值 xff0c count记录遍历了多少个 中序遍历是在中间输出节点 xff0c 所以count在中
  • Linux查看文件占用空间、磁盘剩余、设备挂载情况

    查看文件占用空间 命令为du sh file xff0c 表示disk usage xff0c sh为可选参数 xff0c s表示short xff0c h表示human xff0c 即输出简短的信息 xff0c 适合人类查看 xff0c
  • Linux磁盘分区挂载

    输入lsblk命令查看当前各磁盘分区情况 xff0c 可以看到 xff0c sdb硬盘有1 2 5三个分区 xff0c sdb5挂载在根目录 下 xff08 即根目录的文件都存在sdb5分区 xff09 sda硬盘没有分区也没有挂载到任何目
  • win10 latex - Texlive+Texstudio安装

    安装Texlive环境 通过清华大学开源软件镜像站进行下 xff0c https mirrors tuna tsinghua edu cn ctan systems texlive Images 打开镜像 xff0c 双击bat文件 xff

随机推荐

  • 二叉搜索树的后序遍历序列

    由于输入的是后序遍历序列 xff0c 首先我们可以确定序列的最后一个位置为根节点 由于二叉搜索树的左子树比根节点小 xff0c 根节点比右子树小 xff0c 因此我们需要判断根节点的左右子树是否满足该条件 xff0c 关键是找到其左子树和右
  • 【剑指offer】二叉树中和为某一值的路径(一)

    直接对二叉树进行前序遍历 xff0c 每次累加当前节点的值 xff0c 如果到达叶子节点 xff0c 判断当前累加和是否等于给定值 xff0c 是则返回true xff0c 否则继续遍历二叉树 xff0c 若找不到则返回false span
  • Docker 容器互联

    1 基于 Volume 互联 1 1 存储 Driver Aufs Docker最早支持的driver xff0c 但它只是Linux内核的一个补丁集 Device Mapper xff1a Linux2 6 内核提供的一种从逻辑设备到物理
  • torch.cdist高效计算大矩阵相似度

    问题定义 现有矩阵 A R N C
  • 【剑指offer】二叉搜索树与双向链表

    双向链表从左到右的顺序很明显就是中序遍历二叉树输出的顺序 xff0c 因此核心思想就是使用中序遍历 xff0c 在遍历过程中调整指针的指向 需要用到两个全局变量 xff08 递归的题目不用吝啬全局变量 xff09 xff0c c u r N
  • win10远程计算机

    确保被控制电脑远程功能开启 控制面板 61 61 gt 允许远程访问 选中允许远程连接到此计算机 查看被控制电脑的用户名和ip 命令行 query user xff0c 下面的用户名为远程登录的用户名 密码为改账户的登录密码 xff08 不
  • 【剑指offer】对称的二叉树

    递归法 通过两个指针同时递归遍历左右两个子树 xff0c 判断当前遍历到的两个节点是否相等 如下图 xff0c 需要注意的是 xff0c 左右子树的遍历不是完全一样 xff0c 左子树采用左右遍历 xff0c 右子树采用右左遍历 xff0c
  • 【剑指offer】判断是不是平衡二叉树

    这题只需要在求二叉树深度的基础上扩展一下即可 xff0c 下面为求二叉树深度的代码 span class token keyword public span span class token class name HashMap span
  • Linux查看硬盘属性(机械硬盘/固态硬盘)

    通过命令lsblk d o name rota查看 xff0c 0表示固态硬盘 xff0c 1表示机械硬盘 xff0c sda为机械硬盘 xff0c sdb为固态硬盘
  • python计算众数scipy

    计算如下数组中每一行的众数 xff0c 期望结果 xff0c 第一行为1 xff0c 第二行为3 0 0 1 1 1 2 3 3 2 3 使用scipy 的统计包stats中的mode函数 xff0c 指定第二个维度 xff0c 返回元组
  • 【剑指offer】序列化二叉树

    解题思路 序列化时 xff0c 可以通过各种遍历方法 xff0c 例如层序遍历 递归遍历对二叉树进行遍历 xff0c 遍历过程中将每个节点的值拼接到字符串中 xff0c 注意每个节点之间用一个标识符隔开 xff0c 例如 xff0c 这是为
  • Linux cuda11.1安装torch_scatter,torch-sparse,torch-cluster,torch-spline-conv,torch-geometric

    创建虚拟环境 conda create n torch18 span class token assign left variable python span span class token operator 61 span span c
  • pytorch查看张量占用内存大小

    element size返回单个元素的字节大小 xff0c nelement返回元素个数 span class token keyword import span torch a span class token operator 61 s
  • MySQL8.0 集群安装 (K8S)

    尝试了很多版本的mysql镜像 xff0c 都存在这样那样的的问题 原始需求中 xff0c 需要同时支持x86 64 AMD64 和aarch64 ARM64V8 xff0c 最后找到Oracle官方出品的MySQL Server 8 0镜
  • 使用latex导出IEEE文献格式

    创建一个tex文件 xff0c 内容如下 documentclass span class token punctuation span a4paper span class token punctuation span 10pt span
  • IDEA中设置python解释器(不同虚拟环境)

    按住Ctrl 43 Shift 43 Alt 43 s xff0c 或 File gt Project Structure xff0c 在Module SDK处下拉找到对应的python解释器 xff0c 如果第一次添加python解释器
  • TF-IDF

    TF IDF xff08 term frequency inverse document frequency xff09 是一种用于信息检索与数据挖掘的常用加权技术 TF意思是词频 Term Frequency xff0c IDF意思是逆文
  • 第一次写博客-C/C++软件开发工程师需要学习哪些东西?

    学习路线概述 概述数据结构和算法操作系统计算机网络数据库设计模式 概述 作为一名本科机械电子 xff0c 研究生研究计算机视觉方向的211应届毕业生 xff0c 如何才能从事C C 43 43 软件开发类的工程师呢 xff1f 如果能有机会
  • Vue中使用v-for不能用index作为key值

    今天在改一个项目 xff0c 有一个 lt el tabs gt 的列表循环 xff0c 需要根据权限控制列表项的显示 xff0c 代码如下 xff1a span class token operator lt span template
  • java 冒泡排序 选择排序 插入排序及其异同点

    交换两坐标位置的swap 函数 之后要用到 span class token keyword public span span class token keyword static span span class token keyword