码迷,mamicode.com
首页 > 编程语言 > 详细

合并两个数组

时间:2017-12-02 20:19:50      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:size   proc   数组   strong   nbsp   else   style   return   实现   

【题目】有两个排序的数组A1和A2,内存在A1的末尾有足够的空余空间容纳A2。请实现一个函数,把A2中所有数字插入到A1中,并且所有的数字是排序的。

 

1. 从后往前比较A1和A2中的数字,并把较大的数字复制到A1的合适位置。

 1 public class Main {
 2 
 3     public static void main(String[] args) {
 4 
 5         int[] arr1 = new int[100];
 6         arr1[0] = 1;
 7         arr1[1] = 3;
 8         arr1[2] = 4;
 9         arr1[3] = 7;
10         arr1[4] = 9;
11         arr1[5] = 10;
12         arr1[6] = 23;
13         arr1[7] = 67;
14         int[] arr2 = { 4, 6, 8, 10, 22, 24, 26, 34, 37 };
15 
16         Main main = new Main();
17         int[] result = main.process(arr1, arr2);
18 
19         if (null != result) {
20             for (int i = 0; i < (8 + arr2.length); i++) {
21                 System.out.print(result[i] + " ");
22             }
23         }
24     }
25 
26     public int[] process(int[] arr1, int[] arr2) {
27 
28         if (null == arr1 || null == arr2
29                 || (0 == arr1.length && 0 == arr2.length)) {
30             return null;
31         }
32 
33         if (0 == arr1.length && 0 != arr2.length) {
34             return arr2;
35         }
36 
37         if (0 != arr1.length && 0 == arr2.length) {
38             return arr1;
39         }
40 
41         // 求arr1中非0的元素个数
42         int index = 0;
43         for (int i = 0; i < arr1.length; i++) {
44             if (0 == arr1[i]) {
45                 index = i;
46                 break;
47             }
48         }
49 
50         int p1 = index - 1; // arr1末尾指针
51         int p2 = arr2.length - 1; // arr2末尾指针
52         int p = index + arr2.length - 1; // arr3末尾指针
53 
54         // 从后往前遍历arr1和arr2中的元素,并从后往前赋值到arr1中
55         while (p1 >= 0 && p2 >= 0) {
56             if (arr1[p1] >= arr2[p2]) {
57                 arr1[p--] = arr1[p1--];
58             } else {
59                 arr1[p--] = arr2[p2--];
60             }
61         }
62 
63         while (p1 >= 0) {
64             arr1[p--] = arr1[p1--];
65         }
66 
67         while (p2 >= 0) {
68             arr1[p--] = arr2[p2--];
69         }
70 
71         return arr1;
72     }
73 }

 

合并两个数组

标签:size   proc   数组   strong   nbsp   else   style   return   实现   

原文地址:http://www.cnblogs.com/jiangyi-uestc/p/7955358.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!