【重温篇】八大排序——归并排序

news2025/1/10 12:57:05

思路

归并排序是一种经典的排序算法,采用分治法的思想。它将待排序的数组分成两个较小的子数组,分别对这两个子数组进行排序,然后将排好序的子数组合并成一个有序的数组。

归并排序的主要思路如下:

  1. 分解:将待排序的数组递归地分解成较小的子数组,直到每个子数组只有一个元素为止。这可以通过不断地将数组分成两半来实现。

  2. 解决:对每个子数组进行排序。当子数组只有一个元素时,它已经是有序的。

  3. 合并:将排好序的子数组合并成一个大的有序数组。这是通过比较两个子数组的最前面的元素,并将较小的元素放入新的数组中,然后将相应子数组的指针向后移动来实现的。重复这个过程,直到所有的元素都被放入新数组中。

  4. 递归:重复以上步骤,直到最终整个数组排序完成。

总结一下,归并排序的核心思想是分治和合并。通过递归地将数组分解成较小的子数组,然后对这些子数组进行排序,并最终合并成一个有序的数组。

拆分过程

if(left>=right){
   return;
}

int mid = (left+right)/2;

mergeSort(arr,left,mid);
mergeSort(arr,mid+1,right);

 排序合并

当我们拆分完成之后,其中5和7我们可以认为是有序的,之后我们要将进行合并操作,将两个有序的小数组合并成一个大的有序数组,首先定义一个和当前要合并的数组大小一样的临时数组。

int[] temp = new int[right-left+1];

 之后我们定义两个游标,对两个有序数组内的元素进行比较进行排序并合并到临时数组中,

int s1 = left;
int s2 = mid + 1;
if(arr[s1]<=arr[s2]){
    temp[i++] = arr[s1++];
}else {
    temp[i++]=arr[s2++];
}

 现在我们就可以认为5和7一定是有序的了

添加到临时数组之后需要把数据写回原数组

for(int j = 0;j<temp.length;j++) {
	arr[j+left] = temp[j];
}

接下来的步骤就是递归重复合并的代码了!!!!

上源码

首先强调:注意while循环的条件,画一下图,就能很简单的看出来!

看下图,s2指向空了,7能不能放进去呢?答案显而易见7是不会放进去的,如果没有后面条件就会造成bug。

public class MergeSort {
	public static void main(String[] args) {
		int[] arr = new int[] {5,7,4,2,0,3,1,6};
		mergeSort(arr,0,arr.length - 1);
		System.out.println(Arrays.toString(arr));
	}
	public static void mergeSort(int[] arr,int left,int right) {
        //递归出口
		if(left>=right) {
			return;
		}
		int mid = (left +right)/2;
		
        //拆分
		mergeSort(arr,left,mid,mid);
		mergeSort(arr,mid +1,right,mid);
		
		//合并
		//定义一个临时数组
		int[] temp = new int[right - left +1];
		
		int s1 = left;
		int s2 = mid + 1;
		int i =0;
		while(s1<=mid && s2<=right) {
			if(arr[s1]<=arr[s2]) {
				temp[i++] = arr[s1++];

			}else {
				temp[i++] = arr[s2++];
	
			}
		}
			
		while(s1<= mid) {
			temp[i++] = arr[s1++];
	
		}
		while(s2<=right) {
			temp[i++] = arr[s2++];
			
		}
		
		//将temp中的数据返回
		for(int j = 0;j<temp.length;j++) {
			arr[j+left] = temp[j];
		}
		
	}
}

 

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

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

相关文章

JMETERbeanshell多种姿势获取目标值

beanshell通过vars方式取值 JMETER三种取值方法步骤_securitor的博客-CSDN博客 beanshell通过props方式取值 JMETER取值二_securitor的博客-CSDN博客 beanshell通过source方式取值 JMETER取值三_securitor的博客-CSDN博客 beanshell通过jar包方式取值 JMETER取值四_securitor的…

PHP客服系统-PhpWorkmanChat客服系统修改管理员密码

作为一款流行的开源PHP客服系统&#xff0c;基于thinkphp和workman&#xff0c;跨平台轻量级客服系统源码 管理员表是v2_admin 账户是admin&#xff0c;如果密码忘记了怎么办。可以直接修改数据库表v2_admin &#xff0c;密码规则是md5(密码 加密盐) &#xff0c; 加密盐可以在…

STL源码刨析_stack _queue

目录 一. 介绍 1. stack 介绍 2. queue 介绍 二. 模拟实现 1. stack 模拟实现 2. queue 模拟实现 三. deque 1. deque 接口 2. 底层 一. 介绍 1. stack 介绍 stack&#xff08;栈&#xff09;是一种容器适配器&#xff0c;它提供了一种后进先出&#xff08;LIFO&#xff0…

如何优化APP应用内的广告点击率?提升变现收益?

对于大部分广告主来说&#xff0c;广告点击率&#xff08;CTR&#xff09;越高越好&#xff0c;而点击率又与收益密切相关。如何优化点击率&#xff0c;让应用内的流量售卖收益最大化呢&#xff1f; 说到优化点击率&#xff0c;那么就一定要说说这个名词&#xff1a; 点击率&…

第五章 动态规划(一)——背包问题

文章目录 01背包问题完全背包多重背包分组背包背包练习题2. 01背包问题3. 完全背包问题4. 多重背包问题 I5. 多重背包问题 II9. 分组背包问题 01背包问题 n个物品&#xff0c;每个物品的体积为 v i v_i vi​&#xff0c;价值为 w i w_i wi​&#xff0c;每次只能选择一个物品放…

JavaScript的库——jquery

JavaScript的库——jquery 一、jQuery的hello 将代码写在一个闭包中 二、面试题&#xff1a; jQuery的ready函数和JavaScript的onload事件有什么区别&#xff1f; 是null&#xff0c;因为拿不到box&#xff0c;代码在后面&#xff0c;还没有执行。 所以需要将代码放在后面&am…

ControlNet新玩法!一键生成AI艺术二维码QR

AI绘画又又又又火出圈了&#xff01;这波来源于AI人所发掘的ControlNet for QR Code 话不多说&#xff0c;看看效果图 这张看着极具个性的图像正是一个可以扫描的二维码&#xff0c;通过使用Stable Diffusion和Controlnet生成。由此定制生成个人艺术二维码&#xff0c;选择不同…

前端学习——JS进阶 (Day4)

深浅拷贝 练习 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice…

Antd的Select组件二次封装

提示&#xff1a;Select组件二次封装的目的,是为了在系统里面更方便、简洁地使用Select 这是官方写的使用方法是: import React from react; import { Select } from antd;const handleChange (value: string) > {console.log(selected ${value}); };const App: React.FC …

信息泄露与大数据:隐私安全的挑战与对策

随着大数据时代的到来&#xff0c;我们生活的方方面面都与数据息息相关。然而&#xff0c;随之而来的信息泄露问题也日益严重&#xff0c;给个人隐私和数据安全带来了巨大挑战。本文将围绕信息泄露与大数据展开讨论&#xff0c;探讨其中的问题、原因以及如何应对。 山海鲸大屏 …

langchain +SQLDatabase+Mysql+OpenAI

通过langchain SQLDatabaseMysql来获取数据 参照:https://github.com/hwchase17/langchain/issues/2333 from langchain import OpenAI, SQLDatabase, SQLDatabaseChain from sqlalchemy import create_enginefrom common.keys import OPENAI_API_KEYengine create_engine(m…

Network Dissection 论文阅读笔记

Network Dissection 论文阅读笔记 1. 简介2. 网络刨析2.1 深度视觉表征的可解释性的测量步骤2.2 数据集2.3 可解释神经元评分 3. 实验3.1 对解释的人类评价3.2 Measurement of Axis-Aligned Interpretability3.3 理解层概念3.4 网络架构和监督3.5 训练条件 vs 可解释性3.6 网络…

【二等奖方案】基于人工智能的漏洞数据分类赛题「道可道,非常道」团队解题思路

2022 CCF BDCI 大赛 数字安全公开赛「基于人工智能的漏洞数据分类」赛题二等奖团队「道可道&#xff0c;非常道」战队获奖方案&#xff0c;赛题地址&#xff1a; http://go.datafountain.cn/s57 团队简介 本团队具有丰富的比赛和项目经验。在AI大赛上多次拿到Top成绩&#xf…

2.Docker镜像和容器操作

文章目录 Docker操作Docker镜像操作搜索镜像获取镜像镜像加速下载查看镜像详细信息为镜像添加标签删除镜像导出导入镜像上传镜像 Docker容器操作创建容器查看容器状态启动容器创建并启动容器进入容器停止容器删除容器复制容器文件到宿主机容器的导出导入 Docker操作 ###查看do…

uniapp中超好用(且免费)的安全类插件推荐!(持续更新中)

前几天写了一篇【干货分享】uniapp做的安卓App如何加固&#xff0c;发现收藏的人蛮多的。所以说&#xff0c;更加证明了我说的第一个问题&#xff1a;现在用uniapp的人是越来越多了。 而通过使用uniapp上自带的插件&#xff0c;也是能够实现事半功倍的效果&#xff0c;让不懂前…

简单记录一下剑指offer的编程题(C语言实现)——替换空格反转链表

1. 替换空格 (剑指 Offer 05) 请实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 示例&#xff1a; 输入&#xff1a;s "We are happy." 输出&#xff1a;"We%20are%20happy."简单分析&#xff1a; 新建一个数组&#xff0c;…

《SpringBoot篇》16.SpringBoot整合Elasticsearch

陈老老老板 说明&#xff1a;工作了&#xff0c;学习一些新的技术栈和工作中遇到的问题&#xff0c;边学习边总结&#xff0c;各位一起加油。需要注意的地方都标红了&#xff0c;还有资源的分享. 一起加油。 本文是介绍Elasticsearch用法与SpringBoot整合 1.ES简介 注&#xf…

Solus Linux 4.4版本发布

导读Solus Linux近日更新到4.4版本&#xff0c;作为这个受爱好者欢迎的Linux发行版的最新增量更新&#xff0c;团队仍在努力实现其基于Serpent OS和对Linux发行版的其他重大基本变化的纳入。 Solus 4.4带有各种各样的更新包&#xff0c;还有一些其他的改变&#xff0c;比如现在…

【C++学习记录】(二)--一个C++工程文件里有哪些东西?

写在前面 首先&#xff0c;我有一个完整的C工程文件&#xff0c;文件分别是包含Debug、include、Service和src。 1.了解文件结构: 首先&#xff0c;查看每个文件夹中的内容以了解文件的组织结构。Debug文件夹通常包含与调试相关的文件&#xff0c;include文件夹可能包含头文件…

Innovus:highlight clock tree(高亮时钟树方法)

过往文章链接&#xff1a; ICC2: highlight clock tree&#xff08;高亮时钟树方法&#xff09; innovus也有高亮clock tree的方法 在ccopt之后&#xff0c;使用ctd_win命令打开Clock Tree Debugger (CTD) window。 ctd_trace -from $root_pin -to $sink_pin -color $color ;#…