算法之归并排序(java、python、c++)

在这里插入图片描述

一、JAVA 摘录归并详细分析 ✈✈✈✈✈

package algorithm.归并;import java.util.Arrays;public class Fenzhi {public static void main(String[] args) {int [] arr = {8,4,1,2,7,6,3,5};mergeSort(arr, 0, arr.length-1, new int[8]);System.out.println(Arrays.toString(arr));}public static void mergeSort(int [] arr, int left, int right, int [] tmp) {int mid = (right + left) /2;if(left < right) {mergeSort(arr, left, mid, tmp);mergeSort(arr, mid+1, right, tmp);merge(arr, left, mid, right, tmp);}}public static void merge(int [] arr, int left, int mid, int right, int [] tmp) {int i=left;int j=mid + 1;int n=0;while(i<=mid && j<=right) {if(arr[i] <= arr[j]) {tmp[n] = arr[i++];}else{tmp[n] = arr[j++];}n++;}while(i<=mid) {tmp[n] = arr[i];n++;i++;}while(j<=right) {tmp[n] = arr[j];n++;j++;}int tmpleft = left;n = 0;while(tmpleft <= right) {arr[tmpleft] = tmp[n];tmpleft++;n++;}}
}

二、Python✈✈✈

def merge_sort(num_list):                                                                                                                                                                                                                                                 length = len(num_list)if length <= 1:return num_listmid = length // 2left_l = merge_sort(num_list[:mid])right_l = merge_sort(num_list[mid:])p, q, temp_list = 0, 0, list()len_left, len_right = len(left_l), len(right_l)while len_left > p and len_right > q:if left_l[p] <= right_l[q]:temp_list.append(left_l[p])p += 1else:temp_list.append(right_l[q])q += 1temp_list += left_l[p:]temp_list += right_l[q:]return temp_listif __name__ == '__main__':num_list = [12,33,44,13,2,1,0,-1,10]new_list = merge_sort(num_list)for k, v in enumerate(new_list):num_list[k] = v print('num_list:',num_list)

三、C++ 借鉴文章✈✈✈✈

#include <iostream>                                                                                                                                                                                                                              int n, ar[20], tmp[20];void mergesort(int low, int mid, int high){int i=low;int j=high;n=low;while(i<=mid && j<= high) {if(ar[i]<=ar[j]){tmp[n++]=ar[i++];}else{tmp[n++]=ar[j++];}   }   while(i<=mid) {tmp[n++]=ar[i++];}   while(j<=high) {tmp[n++]=ar[j++];}   for(n=low;n<=high;n++){ar[n]=tmp[n];}   }void merge(int low, int high) {if(low>=high) return;int mid=(low+high)/2;merge(low, mid);merge(mid+1,high);mergesort(low,mid,high);}using namespace std;int main(){cin >> n;for(int i=1;i<=n;i++) {cin >> ar[i];}   merge(1, n); for(int i=1;i<=n;i++) {cout << ar[i] << " ";    }   }

总结

  • python的排序是最简单的。
    印象最深刻的就是切片语法通过【:】冒号获取前后两侧的集合。分厂方便
  • c++的步骤和代码数与java很像

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

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

相关文章

基于STM32的日光温室远程监控系统设计

基于STM32的日光温室远程监控系统设计 一、引言 随着现代农业技术的快速发展&#xff0c;日光温室在农业生产中的应用越来越广泛。为了提高温室作物的产量和品质&#xff0c;实现精准的环境控制&#xff0c;本研究设计了一种基于STM32微控制器的日光温室远程监控系统。该系统…

【Godot4自学手册】第三十七节钥匙控制开门

有些日子没有更新了&#xff0c;实在是琐事缠身啊&#xff0c;今天继续开始自学Godot4&#xff0c;继续完善地宫相关功能&#xff0c;在地宫中安装第二道门&#xff0c;只有主人公拿到钥匙才能开启这扇门&#xff0c;所以我们在合适位置放置一个宝箱&#xff0c;主人公开启宝箱…

Tcpdump -r 解析pcap文件

当我们使用命令抓包后&#xff0c;想在命令行直接读取筛选怎么办&#xff1f;-r参数就支持了这个 当你使用 tcpdump 的 -r 选项读取一个之前捕获的数据包文件&#xff0c;并想要筛选指定 IP 地址和端口的包时&#xff0c;你可以在命令中直接加入过滤表达式。这些过滤表达式可以…

2024 年 Web 前端开发趋势

希腊哲学家赫拉克利特认为&#xff0c;变化是生命中唯一不变的东西。这句话适用于我们的个人生活、行业和职业领域。 尤其是前端开发领域&#xff0c;新技术、开发趋势、库和框架不断涌现&#xff0c;变化并不陌生。最近发生的一些事件正在改变开发人员构建网站和 Web 应用的方…

前端学习<四>JavaScript基础——25-this指向

执行期上下文 当函数执行时&#xff08;准确来说&#xff0c;是在函数发生预编译的前一刻&#xff09;&#xff0c;会创建一个执行期上下文的内部对象。一个执行期上下文定义了一个函数执行时的环境。 每调用一次函数&#xff0c;就会创建一个新的上下文对象&#xff0c;他们…

git 分支-变基

在git中&#xff0c;将一个分支的更改集成到另一个分支有两种主要方式&#xff1a;合并&#xff08;merge&#xff09;和变基&#xff08;rebase&#xff09;。在本节中&#xff0c;将学习什么是变基&#xff0c;如何执行变基操作&#xff0c;为什么它是一个非常强大的工具&…

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题9

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题9 信息安全管理与评估 网络系统管理 网络搭建与应用 云计算 软件测试 移动应用开发 任务书&#xff0c;赛题&#xff0c;解析等资料&#xff0c;知识点培训服务 添加博主wx&#xff1a;liuliu548…

网工交换基础——MUX VLAN

前言&#xff1a; MUX VLAN&#xff08;Multiplex VLAN&#xff0c;多复用VLAN&#xff09;提供了一种通过VLAN进行网络资源控制的机制。例如&#xff0c;在企业网络中&#xff0c;企业员工和企业客户可以访问企业的服务器。对于企业来说&#xff0c;希望企业内部员工之…

Docker安装(一)

一、安装Docker 服务器系统&#xff1a;centos 7 1.本地有docker的首先卸载本机docker yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-selinux \docker-engine-selinux \dock…

算法训练营第43天|LeetCode 1049.最后一块石头的重量Ⅱ 494.目标和 474.一和零

LeetCode 1049.最后一块石头的重量Ⅱ 题目链接&#xff1a; LeetCode 1049.最后一块石头的重量Ⅱ 代码&#xff1a; class Solution { public:int lastStoneWeightII(vector<int>& stones) {int sum 0;int size stones.size();for(int i0;i<size;i){sum st…

整合Mybatis,配置数据库

整合mybatis需要加入起步依赖&#xff1a; <dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId> <version>3.0.0</version> </dependency>引入这个依赖就相当…

RHCE在系统设定延迟任务与定时任务

实验定义 延迟任务和定时任务都是常见的任务调度机制&#xff0c;用于在特定时间点或时间间隔触发执行任务。它们在系统开发中经常被使用。 延迟任务 延迟任务是指在一定的时间间隔之后执行的任务。我们可以指定一个时间延迟&#xff0c;然后在延迟时间过后执行相应的任务。…

软企必备CMMI | 哪些企业可以认证?一文讲解CMMI认证条件周期以及好处!

CMMI&#xff0c;即能力成熟度模型集成&#xff0c;是由美国软件工程研究所制定的一种评价软件企业能力成熟度和过程改进的国际标准。随后在世界形成推广的一种软件评估标准&#xff0c;对企业的软件综合管理形成一套体系建立&#xff0c;用于改善软件质量的方法。 CMMI认证旨…

selenum操作cookie进行免登陆【爬虫必修课1】

Selenium 操作 Cookie 进行免登录 使用 Selenium 自动化登录网站是一个常见的需求。但是直接输入用户名和密码登录非常不安全,同时每次登录都需要重复这个操作也很麻烦。一个更好的方式是使用 Cookie 进行免登录。 这篇博客就来介绍如何使用 Selenium 实现 Instagram 的免登录…

计算机知识介绍,本地MAC地址是什么

MAC地址&#xff0c;全称媒体访问控制地址&#xff08;Media Access Control Address&#xff09;&#xff0c;也称为物理地址或硬件地址。它是网络设备&#xff08;例如网卡、无线网卡&#xff09;的唯一标识符。 MAC地址由48位&#xff08;6个字节&#xff09;二进制数组成&…

Vue3从入门到实战:深度掌握组件通信(下部曲)

5.组件通信方式5-$attrs $attrs的概念&#xff1a; 在Vue中&#xff0c;$attrs 是一个特殊的属性&#xff0c;用于访问父组件向子组件传递的非特定属性。它可以让子组件轻松地获取父组件传递的属性&#xff0c;而无需在子组件中显式声明这些属性。 想象一下你有一个父组件和…

Connection: keep-alive 2

一、请求保持多久后关闭 客户端主动关闭连接&#xff1a;当客户端不再发送请求&#xff0c;并且已经接收到服务器的完整响应后&#xff0c;客户端可以选择关闭连接。这通常发生在客户端已经获取到所需资源后&#xff0c;或者在客户端程序执行完毕后。 服务器主动关闭连接&…

C++进阶(2)-函数

目录 一、函数提高 1.1函数默认参数 1.2函数占位参数 1.3函数重载 1.3.1函数重载概述 1.3.2函数重载注意事项 二、类和对象 2.1封装 2.1.1封装的意义 2.1.2struct和class区别 2.1.3成员属性设置为私有 2.1.4封装案例 2.2对象的初始化和清理 2.2.1构造函数和析构函数 …

【设计模式之美】快速地改善代码质量的几条编程规范(上)

文章目录 一. 命名二. 关于注释三. 代码风格 超实用的改善代码质量的编程规范 一. 命名 关于命名命名的关键是能准确达意。作用域小的变量&#xff08;比如临时变量&#xff09;&#xff0c;可以适当地选择短一些的命名方式。我们可以借助类的信息来简化属性、函数的命名&#…

科技强国路上的创新先行者,以科技创新筑梦未来

随着我国创新驱动发展战略的深入实施&#xff0c;国家科技实力显著增强&#xff0c;正逐步迈向“科技强国”。在今年3月&#xff0c;全国“两会”的政府工作报告中&#xff0c;强调了国家为“科技创新”推出的多项有力举措&#xff0c;同时&#xff0c;“新质生产力”、“人工智…