Hard-题目42:321. Create Maximum Number

转载 2016年05月31日 23:50:01

题目原文:
Given two arrays of length m and n with digits 0-9 representing two numbers. Create the maximum number of length k <= m + n from digits of the two. The relative order of the digits from the same array must be preserved. Return an array of the k digits. You should try to optimize your time and space complexity.
Example 1:
nums1 = [3, 4, 6, 5]
nums2 = [9, 1, 2, 5, 8, 3]
k = 5
return [9, 8, 6, 5, 3]
Example 2:
nums1 = [6, 7]
nums2 = [6, 0, 4]
k = 5
return [6, 7, 6, 0, 4]
Example 3:
nums1 = [3, 9]
nums2 = [8, 9]
k = 3
return [9, 8, 9]
题目大意:
给出两个0-9数字组成的数组nums1和nums2,和一个整数k,求出从nums1和nums2中拿出k个数组成的最大数,其中原来数字在nums1和nums2中的顺序还要保持不变。(见例2,答案是67604而不是76640)。
题目分析:
约束很多的一道麻烦题,看了discuss也不是很能理解,大致意思是枚举所有0-k之间的i,从nums1中取最大的i个子序列,从nums2中取k-i个(如果有这么多个),再将二者以最大字典序归并,维护最大值。具体细节还是没太看懂。
源码:(language:java)

public class Solution {
    public int[] maxNumber(int[] nums1, int[] nums2, int k) {
        int n = nums1.length;
        int m = nums2.length;
        int[] ans = new int[k];
        for (int i = Math.max(0, k - m); i <= k && i <= n; ++i) {
            int[] candidate = merge(maxArray(nums1, i), maxArray(nums2, k - i), k);
            if (greater(candidate, 0, ans, 0)) ans = candidate;
        }
        return ans;
    }
    private int[] merge(int[] nums1, int[] nums2, int k) {
        int[] ans = new int[k];
        for (int i = 0, j = 0, r = 0; r < k; ++r)
            ans[r] = greater(nums1, i, nums2, j) ? nums1[i++] : nums2[j++];
        return ans;
    }
    public boolean greater(int[] nums1, int i, int[] nums2, int j) {
        while (i < nums1.length && j < nums2.length && nums1[i] == nums2[j]) {
            i++;
            j++;
        }
        return j == nums2.length || (i < nums1.length && nums1[i] > nums2[j]);
    }
    public int[] maxArray(int[] nums, int k) {
        int n = nums.length;
        int[] ans = new int[k];
        for (int i = 0, j = 0; i < n; ++i) {
            while (n - i + j > k && j > 0 && ans[j - 1] < nums[i]) j--;
            if (j < k) ans[j++] = nums[i];
        }
        return ans;
    }
}

成绩:
22ms,57.46%,21ms,7.61%

相关文章推荐

[Leetcode] 321. Create Maximum Number 解题报告

题目: Given two arrays of length m and n with digits 0-9 representing two numbers. Create the m...

Leetcode 321. Create Maximum Number

问题描述: Given two arrays of length m and n with digits 0-9 representing two numbers. ...

[leetcode] 321. Create Maximum Number 解题报告

题目链接: https://leetcode.com/problems/create-maximum-number/ Given two arrays of length m and n with...

Leetcode-321. Create Maximum Number

题目:

Leetcode——321.Create Maximum Number

本周的题目是产生最大的数字,题目描述如下: Given two arrays of length m and n with digits 0-9 representing two numbers...

leetcode 321. Create Maximum Number

Given two arrays of length m and n with digits 0-9 representing two numbers. Create the maximum num...

Leetcode 321 - Create Maximum Number(贪心)

题意给两个数组nums1和nums2,和一个数字k,要求从nums1里面和nums2里面分别找出一些数字,构成一个新的数字,并且新的数字最大。并且nums1里面取的数字和nums2里面取的数字要保持相...
  • Lzedo
  • Lzedo
  • 2017年02月08日 22:19
  • 107

leetcode_321 Create Maximum Number

题目分析:给定两个长度分别为m和n的数组,数组元素为0-9,每个数组元素代表一个数字。从这两个数组中选出一些数字,组成一个数组,是这个数组中的数尽可能大,其长度k ...

LeetCode 321. Create Maximum Number(寻找最大数)

原题网址:https://leetcode.com/problems/create-maximum-number/ Given two arrays of length m and n with ...
  • jmspan
  • jmspan
  • 2016年04月25日 02:00
  • 1073

LeetCode 321. Create Maximum Number

由于k的大小不定,所以有三种可能,第一种是当k为0时,两个数组中都不取数;第二种是当k不大于其中一个数组的长度时,有可能只从一个数组中取数;第三种情况是k大于其中一个数组的长度,则需要从两个数组中分别...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hard-题目42:321. Create Maximum Number
举报原因:
原因补充:

(最多只允许输入30个字)