歸并排序算法

文章目錄

  • 歸并排序
    • 一、歸并排序思路
    • 二、歸并排序算法模板
    • 三、題目
      • 代碼

歸并排序

一、歸并排序思路

在這里插入圖片描述

二、歸并排序算法模板

void merge_sort(int q[], int l, int r)
{if (l >= r) return;int mid = l + r >> 1;//中間值merge_sort(q, l, mid);merge_sort(q, mid + 1, r);int k = 0, i = l, j = mid + 1;while (i <= mid && j <= r)if (q[i] <= q[j]) tmp[k ++ ] = q[i ++ ];else tmp[k ++ ] = q[j ++ ];while (i <= mid) tmp[k ++ ] = q[i ++ ];while (j <= r) tmp[k ++ ] = q[j ++ ];for (i = l, j = 0; i <= r; i ++, j ++ ) q[i] = tmp[j];
}

三、題目

給定你一個長度為 n 的整數數列。

請你使用歸并排序對這個數列按照從小到大進行排序。

并將排好序的數列按順序輸出。

輸入格式

輸入共兩行,第一行包含整數 n。

第二行包含 n 個整數(所有整數均在 1~109 范圍內),表示整個數列。

輸出格式

輸出共一行,包含 n 個整數,表示排好序的數列。

數據范圍

1≤n≤100000

輸入樣例:

5
3 1 2 4 5

輸出樣例:

1 2 3 4 5

代碼

#include<iostream>
using namespace std;const int N=1e6+10;int n;
int q[N],tmp[N];//tmp用來存答案數值,然后重新賦值給q數組 void merge_sort(int q[],int l,int r)
{if(l>=r)	return ;int mid=(l+r)/2;merge_sort(q,l,mid),merge_sort(q,mid+1,r);int k=0,i=l,j=mid+1;while(i<=mid&&j<=r){if(q[i]<=q[j])tmp[k++]=q[i++];elsetmp[k++]=q[j++];}while(i<=mid)	tmp[k++]=q[i++];while(j<=r)tmp[k++]=q[j++];for(i=l,j=0;i<=r;i++,j++)q[i]=tmp[j];
}int main()
{scanf("%d",&n);for(int i=0;i<n;i++)scanf("%d",&q[i]);merge_sort(q,0,n-1);for(int i=0;i<n;i++)printf("%d",q[i]);return 0;
} 

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/165571.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/165571.shtml
英文地址,請注明出處:http://en.pswp.cn/news/165571.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

大數據分析與應用實驗任務九

大數據分析與應用實驗任務九 實驗目的 進一步熟悉pyspark程序運行方式&#xff1b; 熟練掌握pysaprkRDD基本操作相關的方法、函數&#xff0c;解決基本問題。 實驗任務 進入pyspark實驗環境&#xff0c;打開命令行窗口&#xff0c;輸入pyspark&#xff0c;完成下列任務&am…

Redis入門教程

1. 什么是NoSql NoSQL一詞最早出現于1998年&#xff0c;是Carlo Strozzi開發的一個輕量、開源、不提供SQL功能的關系數據庫。2009年&#xff0c;Last.fm的Johan Oskarsson發起了一次關于分布式開源數據庫的討論&#xff0c;來自Rackspace的Eric Evans再次提出了NoSQL的概念&am…

onnx導出報錯 | IndexError: index_select(): Index is supposed to be a vector

解決方案&#xff1a; 在torch.onnx.export鐘添加do_constant_foldingFalse&#xff0c;如下 torch.onnx.export(model,(None, text),text_fp32_onnx_path,input_names[text],output_names[unnorm_text_features],export_paramsTrue,opset_version13,verboseTrue,do_constant_…

編程參考 - C++ Code Review: 一個計算器的項目

GitHub - jroelofs/calc: Toy Calculator Toy Calculator 1&#xff0c;拿到一個project&#xff0c;第一眼看&#xff0c;沒有配置文件&#xff0c;說明沒有引入持續集成系統&#xff0c;continuous integration system。 2&#xff0c;然后看cmake文件&#xff0c;使用的子…

使用Python的turtle模塊繪制鋼鐵俠圖案

1.1引言&#xff1a; 在Python中&#xff0c;turtle模塊是一個非常有趣且強大的工具&#xff0c;它允許我們以一個可視化和互動的方式學習編程。在本博客中&#xff0c;我們將使用turtle模塊來繪制鋼鐵俠的圖案。通過調用各種命令&#xff0c;我們可以引導turtle繪制出指定的圖…

第十四章 控制值的轉換 - 在DISPLAYLIST中投影值

文章目錄 第十四章 控制值的轉換 - 在DISPLAYLIST中投影值在DISPLAYLIST中投影值 第十四章 控制值的轉換 - 在DISPLAYLIST中投影值 在DISPLAYLIST中投影值 對于 %String 類型&#xff08;或任何子類&#xff09;的屬性&#xff0c;XML 投影可以使用 DISPLAYLIST 參數。 簡單…

CrystalDiskInfo/CrystalDiskMark/DiskGenius系統遷移

CrystalDiskInfo 主要用于看硬盤的各種信息&#xff0c;包括但不限于硬盤通電時間、通電次數、硬盤好壞狀態 CrystalDiskMark 主要用于測試硬盤的讀寫速度、連續讀寫速度 DiskGenius 主要用于通過U盤裝操作系統后進行&#xff0c;磁盤分區&#xff0c;更改磁盤名、隱藏部分…

【前端知識】Node——http模塊url模塊的常用操作

一、創建簡易Server const http require(http); const URL require(url);const HTTP_PORT 8088;const server http.createServer((req, res) > {// req&#xff1a;request請求對象&#xff0c;包含請求相關的信息&#xff1b;// res&#xff1a;response響應對象&…

【MISRA C 2012】Rule 5.2 在同一作用域和名稱空間中聲明的標識符應該是不同的

1. 規則1.1 原文1.2 分類 2. 關鍵描述3. 代碼實例 1. 規則 1.1 原文 Rule 5.2 Identifiers declared in the same scope and name space shall be distinct Category Required Analysis Decidable, Single Translation Unit Applies to C90, C99 1.2 分類 規則4.2&#xff…

案例014:Java+SSM+uniapp+mysql基于微信小程序的健身管理系統

文末獲取源碼 開發語言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 數據庫&#xff1a;mysql 5.7 開發軟件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序開發軟件&#xff1a;HBuilder X 小程序…

【機器學習 | ARIMA】經典時間序列模型ARIMA定階最佳實踐,確定不來看看?

&#x1f935;?♂? 個人主頁: AI_magician &#x1f4e1;主頁地址&#xff1a; 作者簡介&#xff1a;CSDN內容合伙人&#xff0c;全棧領域優質創作者。 &#x1f468;?&#x1f4bb;景愿&#xff1a;旨在于能和更多的熱愛計算機的伙伴一起成長&#xff01;&#xff01;&…

SpringBoot:ch02 配置文件(日志)

前言 簡單介紹 Spring Boot 中常見的配置文件類型&#xff0c;如 application.properties 和 application.yml 等&#xff0c;并說明它們各自的特點和用途。 一、前期準備 1、新建項目&#xff0c;結構如下 2、添加依賴 <?xml version"1.0" encoding"UTF…

單片機語音芯片開發要解決的問題

在單片機語音芯片開發過程中&#xff0c;可能會遇到多種問題&#xff0c;這些問題可能來自于技術層面&#xff0c;也可能來自于芯片本身的設計和應用層面。下面讓我們具體從芯片的功耗、語音識別的準度、芯片的尺寸和芯片的可靠性四個方面開展討論。 1.芯片的功耗問題 首先&a…

【AIGC重塑教育】AI大爆發的時代,未來的年輕人怎樣獲得機會和競爭力?

目錄 AI浪潮來襲 AI與教育 AI的優勢 延伸閱讀 推薦語 ?作者&#xff1a;劉文勇 來源&#xff1a;IT閱讀排行榜 本文摘編自《AIGC重塑教育&#xff1a;AI大模型驅動的教育變革與實踐》&#xff0c;機械工業出版社出版 AI浪潮來襲 這次&#xff0c;狼真的來了。 AI正迅猛地…

81基于matlab GUI的圖像處理

基于matlab GUI的圖像處理&#xff0c;功能包括圖像顏色處理&#xff08;灰度圖像、二值圖像、反色變換、直方圖、拉伸變換&#xff09;&#xff1b;像素操作&#xff08;讀取像素、修改像素&#xff09;、平滑濾波&#xff08;均值平滑、高斯平滑、中值平滑&#xff09;、圖像…

Java多線程之線程安全問題

文章目錄 一. 線程安全概述1. 什么是線程安全問題2. 一個存在線程安全問題的程序 二. 線程不安全的原因和線程加鎖1. 案例分析2. 線程加鎖2.1 理解加鎖2.2 synchronized的使用2.3 再次分析案例 3. 線程不安全的原因 三. 線程安全的標準類 一. 線程安全概述 1. 什么是線程安全問…

基于C#實現赫夫曼樹

赫夫曼樹又稱最優二叉樹&#xff0c;也就是帶權路徑最短的樹&#xff0c;對于赫夫曼樹&#xff0c;我想大家對它是非常的熟悉&#xff0c;也知道它的應用場景&#xff0c;但是有沒有自己親手寫過&#xff0c;這個我就不清楚了&#xff0c;不管以前寫沒寫&#xff0c;這一篇我們…

【LeetCode刷題筆記】DFSBFS(二)

994. 腐爛的橘子(樹/圖的BFS問題) 解題思路: 多源BFS ,首選找到 所有的腐爛的橘子 ,放入隊列中,然后進行 BFS 廣搜,廣搜的 層數 - 1 就是所需要花費的分鐘數。 在最開始先掃描一遍二維數組,將所有的 腐爛的橘子 加入 隊列 ,同時統計新鮮橘子的數量 <

Blender烘焙AO操作及對應的python代碼

&#xff08;一&#xff09;Blender軟件操作 1. 導入模型&#xff08;這里省略&#xff09; 2. 材質設置 模型使用的所有材質都需要刪除Surface Shader&#xff0c;沒有其他多余的計算&#xff0c;可以大量縮短烘焙時間。刪除之后的只留下一個材質輸出節點&#xff0c;如圖所…