zoukankan      html  css  js  c++  java
  • LeetCode【88. 合并两个有序数组】

    首先想到的方法就是,假设一个nums3数组,然后,比较nums1与nums2的数值大小,然后,放在nums3中,再将nums3转移到nums1中。

    实现起来很麻烦,1、没有考虑到下标问题,结果就ArrayIndexOutOfBoundsException错误,m,n是元素个数,数组下标是从0开始的。

                                 2、过多的if判断,导致我最后修改一个又一个的错误。

    再从看题目,发现nums1中的范围是m+n,那么又想到,可以先将nums2的数据放在nums1后面,再对nums1进行排序。

    class Solution {
        public void merge(int[] nums1, int m, int[] nums2, int n) {
            int i,j;
            int temp;
            for(i = m;i < n+m;i++)
            {
                nums1[i] = nums2[i-m];
            }
            for(i=0;i < m+n;i++)
            {
                for(j=0;j<m+n;j++)
                {
                    if(nums1[i]<nums1[j])
                    {
                        temp = nums1[i];
                        nums1[i] = nums1[j];
                        nums1[j] = temp;
                    }
                }
            }
        }
    }

    其实,在中间排序阶段应该可以优化,我这应该算暴力枚举,两个for都是从0到m+n,不够合算,因为,原先两个数组其实都已经是有序的了。

  • 相关阅读:
    代理模式
    装饰模式
    策略模式
    简单工厂模式
    linux下进程相关操作
    散列表(哈希表)
    转载:最小生成树-Prim算法和Kruskal算法
    二叉排序树和平衡二叉树
    堆排序
    快速排序
  • 原文地址:https://www.cnblogs.com/wzwi/p/10710041.html
Copyright © 2011-2022 走看看