【面试干货】 两个有序数组的合并排序

news2025/1/23 10:26:03

【面试干货】 两个有序数组的合并排序

  • 1、实现思想
  • 2、代码实现


💖The Begin💖点点关注,收藏不迷路💖

1、实现思想

使用两个指针分别指向两个数组的起始位置,然后逐个比较两个指针所指向的元素,将较小的元素依次放入新的数组中,同时移动相应的指针。

2、代码实现

package csdn; 

import java.util.Arrays; // 导入Arrays类,用于数组操作

public class Sort { // 定义名为Sort的类

    public static void main(String[] args) { // 主函数入口
        // 定义两个已排序的数组
        int[] num1 = new int[]{1, 4, 9, 67, 87, 955, 1564, 12354}; 
        int[] num2 = new int[]{-1, 0, 67, 113, 767, 879, 980};

        // 初始化两个指针a和b,分别指向数组num1和num2的起始位置
        int a = 0; 
        int b = 0; 
        // 定义一个新的数组,长度为两个原数组长度之和
        int[] num3 = new int[num1.length + num2.length]; 

        // 遍历新数组
        for (int i = 0; i < num3.length; i++) { 
            // 如果两个数组都还有元素未遍历完
            if (a < num1.length && b < num2.length) { 
                // 比较当前num1和num2的元素,将较小的加入num3,并移动对应指针
                if (num1[a] < num2[b]) { 
                    num3[i] = num1[a]; 
                    a++; // 移动num1指针
                } else {
                    num3[i] = num2[b]; 
                    b++; // 移动num2指针
                }
            } else if (a < num1.length) { // 如果num2已遍历完,但num1还有元素未加入num3
                num3[i] = num1[a]; // 将剩余的num1元素加入num3
                a++; // 移动num1指针
            } else if (b < num2.length) { // 如果num1已遍历完,但num2还有元素未加入num3
                num3[i] = num2[b]; // 将剩余的num2元素加入num3
                b++; // 移动num2指针
            }
        }

        // 打印排序后的数组num3
        System.out.println("排序后:" + Arrays.toString(num3)); 
    }
}

在这里插入图片描述

  1. 初始化两个指针a和b,分别指向两个已排序数组num1和num2的起始位置。
  2. 创建一个新的数组num3,用于存放合并后的结果,其长度为num1和num2长度之和。
  3. 遍历新数组num3,循环条件为i从0到num3的长度减1。
  4. 在循环中,首先判断两个指针a和b是否都没有越界(即是否都小于各自数组的长度):
    • 如果都没有越界,则比较num1[a]和num2[b]的大小:
      • 如果num1[a]小于num2[b],则将num1[a]放入num3中,并将指针a向后移动一位;
      • 如果num1[a]大于等于num2[b],则将num2[b]放入num3中,并将指针b向后移动一位。
    • 如果有一个指针越界了(即数组已遍历完),则将另一个数组剩余部分直接放入num3中,不再进行比较。
  5. 最后,输出排序后的数组num3。

这种合并已排序数组的方法称为"归并"(Merge)算法,时间复杂度为O(n),其中n为两个数组的总长度。


💖The End💖点点关注,收藏不迷路💖

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

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

相关文章

云原生 初识Kubernetes的理论基础

一、k8s 的由来及其技术运用 1.1 k8s的简介 Kubernetes&#xff0c;词根源于希腊语的 舵手、飞行员。在国内又称k8s&#xff08;因为k和s之间有8个字母&#xff0c;所以得名。“国内程序员的幽默”&#xff09;。 作用&#xff1a; 用于自动部署、扩展和管理“容器化&#x…

OpenAI发布会最新消息!ChatGPT新功能发布!

关于即将发布的内容&#xff0c;OpenAI 官方帖子提供的唯一细节是&#xff0c;此次发布将更新 ChatGPT 及其最新模型 GPT-4。 OpenAI 员工程博文&#xff08;Bowen Cheng&#xff09;跟了个帖&#xff0c;「比 gpt-5 更酷」&#xff0c;不过又迅速删帖。 OpenAI 的葫芦里到底卖…

C 深入指针(4)

目录 一、字符指针变量 1 初始化 2 与字符串数组的区别 二、数组指针变量 1 初始化 2 二维数组传参本质 三、函数指针变量 1 初始化 2 用法 四、typedef关键字 五、函数指针数组 一、字符指针变量 1 初始化 //VS2022 x64 #include <stdio.h> int main() {…

前端 JS 经典:数组去重万能方法

前言&#xff1a;只需要掌握这一个方法&#xff0c;就可以对有任何重复的数据数组&#xff0c;进行去重了。 可以自己思考下&#xff0c;怎么对以下对象数组去重&#xff1a; const arr [{ a: 1, b: 2 },{ b: 2, a: 1 },{ a: 1, b: 2, c: { a: 1, b: 2 } },{ b: 2, a: 1, c:…

vue2 中使用audio播放音频

<audio controls ref"audioPlayer" style"width:800px;"><source :src"obj.audioUrl" /></audio> data() {return {obj: {audioUrl: require(../../../../public/audio/video.wav)}}}, 有个地方一定要注意一下. 如果不写req…

推荐丨免费的HTTPS证书在哪里可以申请?怎么申请?

当然&#xff0c;申请HTTPS证书的简化流程大致可以分为以下四个步骤&#xff1a; 1. 确定证书类型&#xff1a; - 首先&#xff0c;根据你的网站需求选择合适的HTTPS证书。常见类型包括&#xff1a;域名验证型&#xff08;DV&#xff09;、组织验证型&#xff08;OV&#xff09…

智慧校园是什么?如何定义?

智慧校园从边界上来说&#xff0c;是指以物联网为中心的智慧化的学校学习、日常生活一体化的环境&#xff0c;经过信息化手法将教育、教务办理和学校日子进行充沛交融&#xff0c;完结智慧化服务和办理的学校形式。 现在智慧校园已成未来趋势&#xff0c;我国的学校环境阅历了巨…

在springboot项目中自定义404页面

今天点击菜单的时候不小心点开了一个不存在的页面&#xff0c;然后看到浏览器给的一个默认的404页面 后端的程序员都觉得这页面太丑了&#xff0c;那么怎么能自定义404页面呢&#xff1f; 很简单&#xff0c;在我们的springboot的静态资源目录下创建一个error包&#xff0c;然…

氮气柜开门停止充氮、开门亮灯和超湿报警功能介绍

氮气柜是一种专门设计用于存储对湿度敏感的电子元器件、半导体材料、精密仪器、化学试剂等物品的设备&#xff0c;它通过注入高纯度氮气来降低内部湿度&#xff0c;以防止物品受潮或氧化。除基本功能外&#xff0c;沐渥科技新增了开门停止充氮、开门亮灯以及超湿报警这三个功能…

特征衍生-多变量交叉组合特征衍生

https://www.bilibili.com/video/BV1Kg411n7jv?p21&vd_source08e23da22e328e8950aeb24d2001d586

【AI绘画】Stable diffusion初级教程08——提示词(prompt)该如何写

今天是一篇干货&#xff0c;干的喝水的那种…… 写之前呢&#xff0c;先给大家打个比方&#xff1a;现在刚入门学习SD的相当于刚上学的小学生&#xff0c;提示词就相当于作文&#xff0c;还是英语作文&#xff0c;如果你总是抄抄抄&#xff0c;不知道作文的要点&#xff0c;语法…

笔记-Windows NFS → 中文乱码导致文件找不到

前提准备 项目中有这么一块业务 1、 脚本同步 这一环&#xff0c;是运维同事通过脚本实现的&#xff0c;所以我没去关注 2、 读取文件并上传 这一环&#xff0c;是我实现的&#xff0c;稳定运行了很长一段时间了&#xff0c;一直没出问题 中文乱码** 直到有一天&#xff0…

Typora + AliyunOSS + PicGo + OneDrive 搭建同步笔记本

文章目录 Typora AliyunOSS PicGo OneDrive 搭建同步笔记本1. 购置阿里云OSS资源2. 配置PicGo3. Typora oneDrive4. 注意 Typora AliyunOSS PicGo OneDrive 搭建同步笔记本 前记: 尝试使用Gitee和Github&#xff0c;效果都十分不理想 Gitee&#xff1a; repository仓库…

什么开放式耳机好用?2024五大爆款机型安利!

​2024年耳机的大热门毫无疑问的是开放式耳机&#xff0c;开放式耳机有着更健康的听音表现和极佳的佩戴舒适度&#xff0c;开放式设计在享受音乐的同时还可以清楚地听到外界的声音&#xff0c;这有助于在户外活动时保持对周围环境的警觉&#xff0c;增加使用时的安全性。作为一…

气膜体育馆的基础设施有哪些—轻空间

随着体育事业的迅速发展和全民健身意识的提升&#xff0c;现代体育场馆设施也在不断更新换代。新型气膜体育馆的出现&#xff0c;解决了传统体育场馆构建审核难、时间长、门槛高的问题&#xff0c;有利于构建多样化的体育场馆&#xff0c;提升人均体育场馆面积。 气膜建筑因其建…

医院内外网文件交互,关键在于安全、效率和便捷

目前&#xff0c;国内医院内外网隔离的网络建设已较为普遍&#xff0c;医院涉及大量患者信息、疾病研究、学术报告等资料&#xff0c;数据具有重要的价值&#xff0c;因此医院的内外网建设成为基本共识。 医院的内外网是相互对应而言的&#xff0c;一般来说&#xff0c;外网指医…

【Python】语句与众所周知【自我维护版】

各位大佬好 &#xff0c;这里是阿川的博客 &#xff0c; 祝您变得更强 个人主页&#xff1a;在线OJ的阿川 大佬的支持和鼓励&#xff0c;将是我成长路上最大的动力 阿川水平有限&#xff0c;如有错误&#xff0c;欢迎大佬指正 本篇博客是在之前的基础上进行的维护 目录 条…

基于CentOS-7搭建hadoop3.3.6大数据集群(保姆级教程)

目录 安装虚拟机 为hadoop用户添加权限 关闭防火墙 修改主机名以及ip地址映射 配置ip 连接xshell &#xff0c;以hadoop用户登录 创建目录并将该文件夹权限赋予hadoop用户 安装配置jdk 关闭虚拟机&#xff0c;克隆其他两个节点 修改主机名和ip地址 配置免密登录 安装…

如何在VS Code中安装插件并进行中文化。

相关文章推荐: 如何下载和安装Visual Studio Code&#xff08;VSCode&#xff09; 在使用Visual Studio Code&#xff08;简称VS Code&#xff09;进行开发时&#xff0c;安装插件可以极大地提升开发效率和使用体验。而将VS Code插件界面进行中文化&#xff0c;则能更好地满足中…

在 Django 中获取已渲染的 HTML 文本

在Django中&#xff0c;你可以通过多种方式获取已渲染的HTML文本。这通常取决于你希望在哪个阶段获取HTML文本。下面就是我在实际操作中遇到的问题&#xff0c;并且通过我日夜奋斗终于找到解决方案。 1、问题背景 在 Django 中&#xff0c;您可能需要将已渲染的 HTML 文本存储…