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

Java 语言实现归并排序算法

【引言】
归并排序算法是一种高效且稳定的排序算法。它采用分治法的思想,将数组反复分割成两个子数组,直到每个子数组只有一个元素。然后将这些子数组逐个合并,最终得到排序完毕的数组。本文将使用Java语言实现归并排序算法,并详细讲解其核心思想和代码实现。

【算法思想】
归并排序的核心思想是分治法。具体步骤如下:

  1. 将数组反复分割成两个子数组,直到每个子数组只有一个元素。
  2. 将两个子数组逐个合并,合并过程中按照元素大小逐次取出元素放入原数组中,得到一个更大的有序子数组。
  3. 重复步骤2,直到所有子数组合并完毕,得到排序完毕的数组。

【Java代码实现】
下面是用Java语言实现归并排序算法的代码:

public class MergeSort {public static void mergeSort(int[] arr, int low, int high) {if (low < high) {int mid = (low + high) / 2;mergeSort(arr, low, mid);mergeSort(arr, mid + 1, high);merge(arr, low, mid, high);}}public static void merge(int[] arr, int low, int mid, int high) {int n1 = mid - low + 1;int n2 = high - mid;int[] leftArr = new int[n1];int[] rightArr = new int[n2];for (int i = 0; i < n1; i++) {leftArr[i] = arr[low + i];}for (int j = 0; j < n2; j++) {rightArr[j] = arr[mid + 1 + j];}int i = 0, j = 0;int k = low;while (i < n1 && j < n2) {if (leftArr[i] <= rightArr[j]) {arr[k] = leftArr[i];i++;} else {arr[k] = rightArr[j];j++;}k++;}while (i < n1) {arr[k] = leftArr[i];i++;k++;}while (j < n2) {arr[k] = rightArr[j];j++;k++;}}public static void main(String[] args) {int[] arr = {5, 2, 8, 3, 1};int n = arr.length;mergeSort(arr, 0, n - 1);System.out.println("排序结果:");for (int num : arr) {System.out.print(num + " ");}}
}

【代码解析】
在代码中,我们定义了两个静态方法。mergeSort方法是归并排序的主要方法,它接受一个整数数组、最低索引和最高索引作为输入,并对数组进行排序。merge方法用于将两个有序子数组合并为一个有序数组。

mergeSort方法中,我们首先使用mid将数组分为两个子数组,然后递归地对两个子数组进行归并排序。最后,我们调用merge方法将两个有序子数组合并为一个有序数组。

main函数中,我们创建了一个测试数组并调用mergeSort方法进行排序。最后,我们将排序结果输出到控制台。

【时间复杂度和稳定性】
归并排序算法的时间复杂度为O(nlogn),其中n表示待排序数组的大小。归并排序是一种稳定的排序算法,因为在合并过程中,如果两个元素相等,我们会优先选择左边的元素。

【总结】
本文使用Java语言实现了归并排序算法,并详细讲解了其核心思想和代码实现。归并排序是一种高效且稳定的排序算法,可用于大规模数据的排序。希望本文对于理解和应用归并排序算法有所帮助。

相关文章:

Java 语言实现归并排序算法

【引言】 归并排序算法是一种高效且稳定的排序算法。它采用分治法的思想&#xff0c;将数组反复分割成两个子数组&#xff0c;直到每个子数组只有一个元素。然后将这些子数组逐个合并&#xff0c;最终得到排序完毕的数组。本文将使用Java语言实现归并排序算法&#xff0c;并详细…...

【Python编程】将同一种图片分类到同一文件夹中

一、数据结构如下&#xff1a; 二、编程工具&#xff1a;Jupyter-Notebook 三、代码&#xff1a; import os import cv2 import shutilpath0os.getcwd()\\apple\\RGB path1os.getcwd()\\apple\\tof_confidence path2os.getcwd()\\apple\\tof_depth path3os.getcwd()\\apple\\…...

Web安全测试(四):XML注入和代码注入

一、前言 结合内部资料&#xff0c;与安全渗透部门同事合力整理的安全测试相关资料教程&#xff0c;全方位涵盖电商、支付、金融、网络、数据库等领域的安全测试&#xff0c;覆盖Web、APP、中间件、内外网、Linux、Windows多个平台。学完后一定能成为安全大佬&#xff01; 全部…...

如何通过内网穿透实现外部网络对Spring Boot服务端接口的HTTP监听和调试?

文章目录 前言1. 本地环境搭建1.1 环境参数1.2 搭建springboot服务项目 2. 内网穿透2.1 安装配置cpolar内网穿透2.1.1 windows系统2.1.2 linux系统 2.2 创建隧道映射本地端口2.3 测试公网地址 3. 固定公网地址3.1 保留一个二级子域名3.2 配置二级子域名3.2 测试使用固定公网地址…...

深入理解c++特殊成员函数

深入理解c特殊成员函数 在c中&#xff0c;特殊成员函数有下面6个&#xff1a; 构造函数析构函数复制构造函数(拷贝构造函数)赋值运算符(拷贝运算符)移动构造函数(c11引入)移动运算符(c11引入) 以Widget类为例&#xff0c;其特殊成员函数的签名如下所示&#xff1a; class W…...

RecyclerView面试问答

RecycleView 和 ListView对比: 使用方法上 ListView:继承重写 BaseAdapter,自定义 ViewHolder 与 converView优化。 RecyclerView: 继承重写 RecyclerView.Adapter 与 RecyclerView.ViewHolder。设置 LayoutManager 来展示不同的布局样式 ViewHolder的编写规范化,ListVie…...

Redis 7 教程 数据持久化

总体 RDB 介绍 RDB 持久化以指定的时间间隔执行数据集的时间点快照 。 把某一时刻的数据和状态以文件的形式写到磁盘上,即使出现故障宕机,快照文件也不会丢失,数据的可靠性得到保证。快照文件就是RDB(Redis DataBase)文件(dump.rdb) 作用 在指定的时间间隔内将内存中的数…...

【ArcGIS微课1000例】0072:如何生成空间权重矩阵

严重声明:本文来自专栏《ArcGIS微课1000例:从点滴到精通》,为CSDN博客专家刘一哥GIS原创,原文及专栏地址为:(https://blog.csdn.net/lucky51222/category_11121281.html),谢绝转载或爬取!!! 文章目录 一、空间权重矩阵工具介绍二、ArcGIS生成空间权重矩阵三、注意事项…...

【芯片设计封装与测试】芯片测试目的、方法、分类及案例

目录 1.芯片测试概述&#xff08;目的、方法&#xff09; 1.1.测试在芯片产业价值链上的位置 2.测试如何体现在设计的过程中 2.1.半导体测试定义与基本工作机制 2.2.半导体测试环节分类及对应设备 2.3.设计验证 3.测试的各种类型 3.1.抽样测试和生产全测 3.2.测试相关…...

k8s集群证书过期解决

一、k8s集群证书过期解决 问题现象 K8S集群证书过期后&#xff0c;会导无法创建Pod&#xff0c;通过kubectl get nodes也无法获取信息&#xff0c;甚至dashboard也无法访问。 执行命令发现报错&#xff1a; Unable to connect to the server: x509: certificate has expire…...

Linux学习之Ubuntu 20.04在github下载源码安装Openresty 1.19.3.1

参考的博文&#xff1a;《在 Ubuntu 上使用源码安装 OpenResty》 《OpenResty 安装安装详解-Ubuntu》 《Linux学习之CentOS 7源码安装openresty》 https://openresty.org/en/download.html是官网下载网址&#xff0c;页面往下拉有下载的链接。 https://github.com/openresty…...

bootloader串口更新程序[瑕疵学习板]

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、储备知识二、程序步骤2.程序展示1.bootloader2.然后是主运行函数总结前言 很久没有更新文章了。最近工作太忙,没有学习很多的知识,然后这两天不忙了,就学习了一下bootloader的程序升级…...

浅谈视频汇聚平台EasyCVR视频平台在城市安全综合监测预警台风天气中的重要作用

夏日已至&#xff0c;台风和暴雨等极端天气频繁出现。在城市运行过程中&#xff0c;台风所带来的暴雨可能会导致城市内涝等次生灾害&#xff0c;引发交通瘫痪、地铁停运、管网泄漏爆管、路面塌陷、防洪排涝、燃气爆炸、供热安全、管廊安全、消防火灾等安全隐患&#xff0c;影响…...

GaussDB技术解读系列:高级压缩之OLTP表压缩

8月16日&#xff0c;第14届中国数据库技术大会&#xff08;DTCC2023&#xff09;在北京国际会议中心顺利举行。在GaussDB“五高两易”核心技术&#xff0c;给世界一个更优选择的专场&#xff0c;华为云数据库GaussDB首席架构师冯柯对华为云GaussDB数据库的高级压缩技术进行了详…...

管理类联考——英语二——实战篇——大作文——图表——静态图表——第一段

第一句:What is clearly presented in the above 图表类型 is the statistics of 主题词 1. 翻译:从上述图表类型中我们能够清晰地得知有关主题词1的数据。 [备注1]:本句对图表进行整体描述,无需描述具体各项内容所占比例,只需提出主题词的哪方面的有关数据…...

https 的ssl证书过期处理解决方案(lighthttpd)

更换证书&#xff1a;lighthttpd 配置文件位置&#xff1a;/opt/vmware/etc/lighttpd/lighttpd.conf &#xff08;配置文件的最底部 G快速来到底部&#xff09; 方案一&#xff1a;阿里云申请免费的证书 这里公司内网环境没有配置域名&#xff0c;可以创建一个临时域名&…...

【java】【idea2023版】Springboot模块没有.iml文件的问题

目录 方法一&#xff1a; 1、首先鼠标选中对应的对应的模块 &#xff0c;按两下Ctrl键 2、project中选择对应的模块 3、运行mvn idea:module 命令​编辑 方法二&#xff1a; 1、可以右键点击open Terminal 2、然后在打开的Terminal里输入 方法一&#xff1a; 1、首先鼠…...

Qt QScrollArea使用

在使用QScrollArea时&#xff0c;有几个注意事项需要考虑&#xff1a; 设置合适的小部件&#xff08;widget&#xff09;大小策略&#xff1a; 确保将要放置在QScrollArea中的小部件设置为合适的大小策略。这将确保小部件可以根据需要进行扩展&#xff0c;以适应滚动区域的大小…...

Unity3d:GameFramework解析:实体,对象池,资源管理,获取计数,引用计数,自动释放

基本概念 1.GF万物基于引用池IReference 2.ObjectBase : IReference类的m_Target持有unity中Mono&#xff0c;资源&#xff0c;GameObejct 3.AssetObject : ObjectBase类m_Target持有Assetbundle中的Asset&#xff0c;具有获取&#xff0c;引用两个计数管理释放 4.ResourceObj…...

Django基础6——数据模型关系

文章目录 一、基本了解二、一对一关系三、一对多关系3.1 增删改查3.2 案例&#xff1a;应用详情页3.2 案例&#xff1a;新建应用页 四、多对多关系4.1 增删改查4.2 案例&#xff1a;应用详情页4.3 案例&#xff1a;部署应用页 一、基本了解 常见数据模型关系&#xff1a; 一对一…...

NHSE完整指南:动物森友会存档编辑器的终极使用手册

NHSE完整指南&#xff1a;动物森友会存档编辑器的终极使用手册 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE 还在为《集合啦&#xff01;动物森友会》中收集稀有物品而烦恼吗&#xff1f;想快速…...

从SPL到main_loop:手把手调试i.MX6ULL的U-Boot启动全流程(附GDB实战)

从SPL到main_loop&#xff1a;手把手调试i.MX6ULL的U-Boot启动全流程&#xff08;附GDB实战&#xff09; 在嵌入式系统开发中&#xff0c;U-Boot作为最常用的Bootloader之一&#xff0c;其启动流程的理解和调试能力是开发者必须掌握的核心技能。本文将聚焦i.MX6ULL平台&#xf…...

基于龙芯2K1000LA的可信计算在工业边缘安全中的实践

1. 项目概述&#xff1a;当“可信计算”遇上工业边缘 最近在做一个工业数据采集与边缘处理的项目&#xff0c;客户对数据安全的要求提到了前所未有的高度。他们不仅担心数据在传输过程中被窃取&#xff0c;更担心边缘设备本身被恶意篡改&#xff0c;导致采集的数据在源头就“失…...

AI智能体在加密货币领域的架构设计与实战指南

1. 项目概述&#xff1a;当AI智能体闯入加密世界最近在GitHub上闲逛&#xff0c;发现一个挺有意思的项目&#xff0c;叫cutupdev/Crypto-AI-Agent。光看名字&#xff0c;两个最火的概念——“Crypto”&#xff08;加密货币&#xff09;和“AI Agent”&#xff08;人工智能体&am…...

生物信息学新手必看:用K-means和WGCNA分析转录组数据的保姆级流程(附R代码)

生物信息学实战&#xff1a;从K-means到WGCNA的转录组分析全流程指南 第一次接触转录组数据分析时&#xff0c;我盯着满屏的基因表达矩阵完全无从下手。那些论文里看似流畅的分析流程&#xff0c;在实际操作时却处处是坑——数据格式报错、参数设置不合理、结果解读模糊...这正…...

.NET逆向工程新选择:dnSpyEx调试器与程序集编辑全解析

.NET逆向工程新选择&#xff1a;dnSpyEx调试器与程序集编辑全解析 【免费下载链接】dnSpy Unofficial revival of the well known .NET debugger and assembly editor, dnSpy 项目地址: https://gitcode.com/gh_mirrors/dns/dnSpy 你是否曾面对一个没有源代码的.NET程序…...

10个UTF8-CPP最佳实践:让你的C++ Unicode处理更高效

10个UTF8-CPP最佳实践&#xff1a;让你的C Unicode处理更高效 【免费下载链接】utfcpp UTF-8 with C in a Portable Way 项目地址: https://gitcode.com/gh_mirrors/ut/utfcpp UTF8-CPP是一个轻量级的C库&#xff0c;提供了便捷的UTF-8编码和解码功能&#xff0c;帮助开…...

超声波,毫米波,激光雷达

一、技术原理与核心特性 ‌1.超声波传感器‌ &#xff08;1&#xff09;原理‌&#xff1a;利用20kHz以上机械波的反射时间差&#xff08;ToF&#xff09;测距&#xff0c;典型工作频率40-58kHz。 &#xff08;2&#xff09;核心特性‌&#xff1a; 非接触式测量&#xff0…...

Kirara-AI:全栈AI应用开发框架,快速构建生产级智能助手

1. 项目概述&#xff1a;一个面向开发者的AI应用快速构建框架最近在折腾AI应用开发的朋友&#xff0c;应该都体会过那种“从想法到原型”的中间环节有多磨人。你想做一个能联网搜索的智能客服&#xff0c;或者一个能处理多格式文档的问答助手&#xff0c;光是搭建基础环境、处理…...

完美解决VS Code/Cursor远程连接报错:远程主机不满足运行 VS Code 服务器的先决条件(附AI编程最佳实践)

完美解决VS Code/Cursor远程连接报错&#xff1a;远程主机不满足运行 VS Code 服务器的先决条件&#xff08;附AI编程最佳实践&#xff09; &#x1f4a1; 背景与痛点 最近在接手维护一个老项目&#xff0c;服务器是腾讯云的轻量应用服务器&#xff0c;装了宝塔面板。在经历了一…...