- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563425 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174250
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
: @9 a! V! A% Z2 D0 J4 b
y0 k+ r- U# ^9 p' H
神级基础排序——归并排序7 |7 b5 v6 Z1 \! O) x% B# `
- L c$ x& [0 p: ^归并排序的介绍
" ?- [. A5 Z% ^9 U
2 t9 k% B- L/ j归并排序(英语:Merge sort,或Mergesort),是创建在归并操作上的一种有效的排序算法,其时间复杂度为O(N*logN)。1945年由约翰·冯·诺伊曼首次提出。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,且各层分治递归可以同时进行。% e: X1 d; Q; i/ Y3 n2 {/ ]
概念6 g3 R$ w g: P8 d- n) \
' B5 T7 V7 w' N" Q8 v8 D9 N
是利用递归与分治的技术将数据序列划分为越来越小的半子表,再对半子表排序,最后再用递归方法将排好序的半子表合并成越来越大的有序序列。
7 J6 d4 H2 } t a }# D. k核心思想
, b# u; E, o* u; U h6 c! W$ A) f
) C* _# i+ f8 P$ t7 \: t将两个有序的数列合并成一个大的有序的序列。通过递归,层层合并,即为归并。$ E( H- Y" r+ K' @" Q: I4 @
) V7 G5 Q" s* g- e3 o- H6 H/ I+ Y- f5 y
实现代码
( m+ F* F+ C% C) x# [8 z5 A$ Gimport java.util.Arrays;; v* | B, K1 d- B: `& s
5 A3 b/ z& X% Z* k# W( x
/**
9 i: ]1 }0 ~2 \+ n- ]% D * @Author god-jiang
& V5 ? b4 A% e4 U5 ` * @date 2020/1/13
0 [+ X( D' L9 {* M% X* W# x# x */
& ^0 x3 D% D! [( Y. \9 g//归并排序,时间复杂度为O(N*logN),空间复杂度为O(N)
8 U5 r- w# D/ @3 w+ A8 |! n; Z- Kpublic class MergeSort {/ E+ T/ E: S9 x8 b2 b! [3 Y
public static void MergeSort(int[] arr, int start, int end) {
+ c1 X, t9 h( v: B //分治的结束条件
$ u5 p8 w# d( w: { if (start >= end) {1 }$ s1 j" \+ e# w! ~
return;& E# E) C2 C* b: \9 q
}
/ H% n& T+ r2 F //保证不溢出取start和end的中位数$ _' S }" W# ~) C2 _( s
int mid = start + ((end - start) >> 1);
0 l, I" v8 R) j //递归排序并且合并
: O' V \1 A" d4 G+ \ MergeSort(arr, start, mid);& R2 n4 n. i8 ] y# U
MergeSort(arr, mid + 1, end);
; u- c6 ]2 M% V6 `" P& c" v Merge(arr, start, mid, end);
$ g2 N/ P* I3 S }
) o3 m4 e) A6 B1 C% ?# u
$ S* x* e9 `" T+ l2 N //合并3 I0 C1 X( m6 F" |* Z4 I
public static void Merge(int[] arr, int start, int mid, int end) {
0 `' l6 Z2 B0 M) D( j. t int[] temp = new int[end - start + 1];
c: b4 H' T# I* X. j5 y$ W int p1 = start;
3 F; W- [4 ~' _* G: c int p2 = mid + 1;
! j9 _; P7 S1 X4 }& ~ N4 _( _ int p = 0;/ c! i6 n, w% t! m/ \) ?6 Q( m
while (p1 <= mid && p2 <= end) {
, E8 }/ A1 C8 ^- r1 r9 Z4 M if (arr[p1] > arr[p2]) {
1 w! V! B6 c# b3 u, L( s8 ]8 @ temp[p++] = arr[p2++];
* Q, p/ A4 j6 H* W7 X } else {3 ]: D5 B/ F+ m) u( n3 r
temp[p++] = arr[p1++];
* l! {* P0 O8 i( L; i" l+ j3 q- i- r }2 l. D# {" u$ J. ?& l
}6 |2 o. b8 t0 x& ]9 o& S9 V
while (p1 <= mid) {
: O/ H+ U# o7 P$ R temp[p++] = arr[p1++];
7 t7 l% w6 G% E }
, c9 ]0 _. u7 N: j n j while (p2 <= end) {
8 n0 J4 f3 h6 p( L" ?! l% O1 q6 _ temp[p++] = arr[p2++];
! G( ]0 x& o7 W! b$ S8 ~* C% w+ O }
1 [- m7 H7 G- T" A! g for (int i = 0; i < temp.length; i++) {1 Q% e8 _. r; Q# ]# k3 A
arr[i + start] = temp;5 Y9 H+ }+ Z/ G2 E/ ]2 r
}) k* @. s; d! A& C
}
9 Z0 ~! [) h) v8 C6 d% Z
% H9 X7 W/ P0 h' q! f public static void main(String[] args) {
; s6 \6 q& K- q, m/ g$ ? int[] a = {2, 4, 6, 1, 3, 7, 9, 8, 5};
% |6 T5 ]* g4 q MergeSort(a, 0, a.length - 1);0 J( C" u, b% B3 M/ s, [
System.out.println(Arrays.toString(a));# r2 Q( V- _9 V# B
}
, h' i) B! U& @% n( r5 _+ L}
# O! R8 ]7 R, r n
$ k3 Q8 Y7 a4 ?8 X) q Z- X# y; Y+ |& X* p
运行截图* T" h1 g! n% W4 O7 ?+ n6 C. G
7 r( E+ p8 c8 s: Z. K1 i, @/ h
6 j0 [- `* o! S! F) M/ `2 {: M: g3 Q; G
1、以上就是今天分享的归并排序,时间复杂度为O(N*logN),空间复杂度为O(N)
( D0 R# H$ J" k6 ]3 J2、归并排序的额外空间复杂度可以做到O(1),但是非常难,不需要掌握,有一篇论文”归并排序内部缓存法”可以做到0 z X7 e' D6 c" t$ N
。
4 Z y: h. h6 A R( ~( O$ _% ]7 b4 ~原文链接:https://blog.csdn.net/weixin_37686415/article/details/105180035
+ z. U5 q1 D( ^. x; y
: ^1 { G x* Q( G
7 |7 t0 x! }8 K2 \* f; A |
zan
|