归并排序算法(Java实现)

1.归并排序算法思想

也称合并排序算法,是将两个或两个以上的有序数据序列合并成一个新的有序数据序列。该算法采用分治法(Divide and Conquer)的思想,将待排序的序列分成若干个子序列,分别对子序列进行排序,然后将有序的子序列合并成一个大的有序序列
注:将几个有序队列合并成一个新的有序数据队列就称为几路归并排序算法

2.归并排序算法实现步骤

归并排序的基本步骤如下:
(1)分解
将待排序的序列分成若干个子序列,每个子序列都是有序的。这是通过递归实现的,每次递归都将原序列分成两个子序列
(2)解决
对每个子序列进行排序。这是通过递归调用的方式实现的,递归调用归并排序函数对子序列进行排序。
(3)归并
将已排序的子序列归并成一个大的有序序列。这是通过归并操作实现的,将两个有序的子序列归并成一个新的有序序列。在归并的过程中,采用归并算法(Merge Algorithm)将两个有序的子序列归并成一个新的有序序列。具体操作如下:
1)初始化两个指针i和j,分别指向两个子序列的起始位置。
2)比较两个指针所指向的元素,将较小的元素复制到一个临时数组中,然后将指针加1,继续比较下一个元素。
3)当一个指针到达子序列的末尾时,将另一个子序列剩余的元素复制到临时数组中。
4)将临时数组中的元素复制回原数组,完成合并操作。
通过递归调用和合并操作,最终得到一个有序的序列

3.归并排序算法性能分析

性能性能指标
最坏时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
最好时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
平均时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
空间复杂度O(n)
稳定性稳定

4.归并排序算法代码实现(Java实现)

public class Demo {public static void main(String[] args) {int[] arr = new int[]{1,2,3,4,5,6,7,8,9,10};mergeSort(arr,0,arr.length-1);for(int i:arr){System.out.println(i);}}//归并排序的归并操作public static void merge(int[] arr,int low,int mid ,int high){int i,j,k;int[] tempArr = new int[arr.length];//辅助数据for(k = low; k <=high; k++){ //将原数组复制到辅助数组中tempArr[k] = arr[k];}//arr[low...mid]和arr[mid+1...high]各自有序,将两个部分归并for(i=low, j=mid+1, k=i; i<=mid && j <= high; k++){if(tempArr[i] > tempArr[j]){ //“>”号代表升序,“<”号代表降序arr[k] = tempArr[i++];}else{arr[k] = tempArr[j++];}}while(i <= mid){ //将左半部分的剩余元素依次放入到新数组中arr[k] = tempArr[i++];k++;}while( j <= high){ //将右半部分的剩余元素依次放入到新数组中arr[k] = tempArr[j++];k++;}}//归并排序的递归部分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); //归并}}
}

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

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

相关文章

十五.流程控制与游标

流程控制与游标 1.流程控制1.1分支结构之IF1.2分支结构值CASE1.3循环结构之LOOP1.4循环结构之WHILE1.5循环结构之REPEAT1.6跳转语句之LEAVE语句1.7跳转语句之ITERATE语句 2.游标2.1什么是游标2.2使用游标步骤4.3举例4.5小结 1.流程控制 解决复杂问题不可能通过一个 SQL 语句完…

linux系统服务器A读取远程linux系统服务器B文件(以cv读图文件为列)

文章目录 前言一、读取远程文件 二、应用解释 前言 当一个服务器需要处理另一个服务器上已知图像的绝对路径时&#xff0c;可以使用 Paramiko 库连接到远程服务器并读取图像&#xff0c;然后使用 OpenCV&#xff08;cv2&#xff09;库在本地服务器上加载和处理图像。以下是示例…

C# Winform翻牌子记忆小游戏

效果 源码 新建一个winform项目命名为Matching Game&#xff0c;选用.net core 6框架 并把Form1.cs代码修改为 using Timer System.Windows.Forms.Timer;namespace Matching_Game {public partial class Form1 : Form{private const int row 4;private const int col 4;p…

简单介绍JDK、JRE、JVM三者区别

简单介绍JDK vs JRE vs JVM三者区别 文编|JavaBuild 哈喽&#xff0c;大家好呀&#xff01;我是JavaBuild&#xff0c;以后可以喊我鸟哥&#xff0c;嘿嘿&#xff01;俺滴座右铭是不在沉默中爆发&#xff0c;就在沉默中灭亡&#xff0c;一起加油学习&#xff0c;珍惜现在来之不…

Python:正则表达式之re.group()用法

Python正则表达式之re.group()用法学习笔记 正则表达式是在处理字符串时非常有用的工具&#xff0c;而re.group()是在匹配到的文本中提取特定分组内容的方法之一。 1. re.group()的基本用法 在正则表达式中&#xff0c;通过圆括号可以创建一个或多个分组。re.group()用于获取…

【samba】Ubuntu20.04安装 error255解决方法

目录 使用samba报错 net usershare returned error 255时&#xff08;如下图&#xff09;解决方法如下&#xff1a; 1、安装 Samba 服务&#xff1a; 2、配置 Samba 共享&#xff1a; 3、设置 Samba 用户密码&#xff1a; 4、重启 Samba 服务&#xff1a; 6、在 Windows 上…

mysql 下载和安装和修改MYSQL8.0 数据库存储文件的路径

一、第一步:下载步骤 下载链接&#xff1a;MySQL :: Download MySQL Installer 选择版本8.0.35&#xff0c;社区版&#xff0c; 点击 Download 下载 安装包 二、第二步:安装步骤 添加环境变量&#xff0c;C:\Program Files\MySQL\MySQL Server 8.0\bin 可以点开MySQL 8.0 Co…

Linux知识点易错点总结(1)

linux 2.6.* 内核默认支持的文件系统&#xff1a;ext3 ext2 ext4 xfsext2:全称Linux extended file system, extfs,即Linux扩展文件系统&#xff0c;ext2为第二代xfs:XFS一种高性能的日志文件系统&#xff0c;2000年5月&#xff0c;Silicon Graphics以GNU通用公共许可证发布这套…

C++基础1

一、形参带默认值的函数 二、inline内联函数 内联函数是一种在编译器处理时&#xff0c;将函数的实际代码插入到调用处的方法。通常&#xff0c;函数调用涉及一定的开销&#xff0c;包括保存和恢复调用现场、跳转到函数的代码位置等。而内联函数通过在调用处直接插入函数的代码…

Django的模板语言

文章目录 模板语法变量标签过滤器注释 组件引擎模板上下文加载器上下文处理器 模板引擎的支持配置用法引擎内置后端 模板 作为一个网络框架&#xff0c;Django 需要一种方便的方式来动态生成 HTML。最常见的方法是依靠模板。一个模板包含了所需 HTML 输出的静态部分&#xff0…

Centos7安装K8S

Centos7安装K8S 安装过程中没有出现的错误可以往下 根据以前一些博主写的博客&#xff0c;在小阳翻了不下几十篇博客之后&#xff0c;我果断是放弃了&#xff0c;于是找到了官网地址&#xff0c;然后也有坑 1. 关闭防火墙 systemctl stop firewalld systemctl disable firew…

MySQL的各种日志

目录 一、错误日志 二、二进制日志 1、介绍 2、作用 3、相关信息 4、日志格式 5、查看二进制文件 6、二进制日志文件删除 三、查询日志 四、慢日志 一、错误日志 记录MySQL在启动和停止时&#xff0c;以及服务器运行过程中发生的严重错误的相关信息&#xff0c;当数据库…

Hive使用shell调用命令行特殊字符处理

1.场景分析 数据处理常用hive -e的方式&#xff0c;通过脚本操作数仓&#xff0c;过程中常常遇到特殊字符的处理&#xff0c;如单双引号、反斜杠、换行符等&#xff0c;现将特殊字符用法总结使用如下&#xff0c;可直接引用&#xff0c;避免自行测试的繁琐。 2.特殊字符处理 …

16.桥接模式

桥接模式 介绍 桥接模式是一种结构型设计模式&#xff0c;它通过将抽象部分与实现部分分离&#xff0c;使它们可以独立变化。这种模式通过组合的方式来实现&#xff0c;而不是继承。桥接模式通过将抽象和实现解耦&#xff0c;从而实现抽象和实现的分离&#xff0c;使得系统更加…

Java基础-Java基础知识-运算符-笔记

1.运算符 算数运算符&#xff1a; - * / % 赋值运算符&#xff1a; 定义变量的语法规则&#xff1a;类型 变量名 变量值 比较运算符&#xff1a;> < > < ! 逻辑运算符&#xff1a; &&&#xff1a;断路与&#xff0c;两边全…

Java零基础——Vue基础篇

1.【熟悉】Vue简介 1.1 简介 它是一个构建用户界面单页面的框架 Vue是一个前端框架 https://www.pmdaniu.com/#file UI网站 UI 一般开发者使用蓝湖 工具 看着UI图 写接口 https://lanhuapp.com/web/#/item 是一个轻量级的MVVM&#xff08;Model-View-ViewModel&#xff…

Spring Boot - Application Events 的发布顺序_ApplicationStartingEvent

文章目录 概述Code源码分析 概述 Spring Boot 的广播机制是基于观察者模式实现的&#xff0c;它允许在 Spring 应用程序中发布和监听事件。这种机制的主要目的是为了实现解耦&#xff0c;使得应用程序中的不同组件可以独立地改变和复用逻辑&#xff0c;而无需直接进行通信。 …

MySQL——锁

1 全局锁 上锁后&#xff0c;整个数据库处于只读状态 flush tables with read lock 释放&#xff1a; unlock tables 应用&#xff1a;用于全库逻辑备份 缺点&#xff1a;如果数据量很大&#xff0c;备份会花很多时间&#xff0c;只能读数据&#xff0c;造成业务停滞 如…

SpringBoot 基础介绍以及相关可实现的功能思路

文章目录 简介start 依赖自定义Banner日志管理devtools统一返回接口接口参数校验自定义异常调用远程接口使用 简介 Spring Boot 是基于Spring的开发开发框架&#xff0c;Spring 的缺点是具有大量的配置文件&#xff0c;使用 SpringBoot 约定大于配置&#xff0c;可以让开发者专…

VMware虚拟机忘记密码操作方法

下面已openEuler虚拟机为例&#xff1a; 1、点击重启时&#xff0c;一直按esc&#xff08;鼠标点击一下&#xff0c;确保鼠标在你的虚拟机里面&#xff09; 2、一直到进入到如下页面按e键&#xff08;可能会略有不同&#xff09; 3、按e键后跳转到如下页面 4、在该页面输入 in…