程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> LeetCode | Merge Sorted Array

LeetCode | Merge Sorted Array

編輯:C++入門知識

題目

Given two sorted integer arrays A and B, merge B into A as one sorted array.

Note:
You may assume that A has enough space (size that is greater or equal to m + n) to hold additional elements from B. The number of elements initialized in A and B are m andn respectively.

分析

從後往前歸並就可以不用額外空間了。

代碼

public class MergeSortedArray {
	public void merge(int A[], int m, int B[], int n) {
		int i = m - 1;
		int j = n - 1;
		while (i >= 0 && j >= 0) {
			if (A[i] > B[j]) {
				A[i + j + 1] = A[i];
				--i;
			} else {
				A[i + j + 1] = B[j];
				--j;
			}
		}
		while (j >= 0) {
			A[j] = B[j];
			--j;
		}
	}
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved