【每日一题Day342】LC2578最小和分割 | 贪心

简介: 【每日一题Day342】LC2578最小和分割 | 贪心

最小和分割【LC2578】

给你一个正整数 num ,请你将它分割成两个非负整数 num1 和 num2 ,满足:

num1和 num2直接连起来,得到 num各数位的一个排列。

换句话说,num1 和 num2 中所有数字出现的次数之和等于 num 中所有数字出现的次数。

num1 和 num2 可以包含前导 0 。

请你返回 num1 和 num2 可以得到的和的 最小 值。

注意:

num 保证没有前导 0 。

num1 和 num2 中数位顺序可以与 num 中数位顺序不同。

  • 思路
  • 局部最优:统计num中每个数字的出现次数,从0开始逐位构造,使两个数字的最高位最小
  • 全局最优:使num1和num2的和最小
  • 实现
class Solution {
    public int splitNum(int num) {
        // 贪心构造:高位一定是较小值
        int[] count = new int[10];
        while(num > 0){
            count[num % 10]++;
            num /= 10;
        }
        int num1 = 0, num2 = 0;
        int index = 0, i = 0;
        while (i < 10){
            if (count[i] == 0){
                i++;
            }else if ((index & 1) == 0){
                num1 = num1 * 10 + i;
                count[i]--;
                index++;
            }else{
                num2 = num2 * 10 + i;
                count[i]--;
                index++;
            }
        }
        return num1 + num2;
    }
}

复杂度

时间复杂度:O ( log ⁡ n u m )

空间复杂度:O ( C )

目录
相关文章
|
8月前
【每日一题Day297】LC1444切披萨的方案数 | 动态规划+二维前缀和
【每日一题Day297】LC1444切披萨的方案数 | 动态规划+二维前缀和
77 0
|
8月前
【每日一题Day149】LC2389和有限的最长子序列 | 贪心+前缀和+二分查找
【每日一题Day149】LC2389和有限的最长子序列 | 贪心+前缀和+二分查找
50 0
|
8月前
【每日一题Day302】LC849到最近的人的最大距离 | 贪心+分类讨论
【每日一题Day302】LC849到最近的人的最大距离 | 贪心+分类讨论
63 0
|
8月前
【每日一题Day133】LC2373矩阵中的局部最大值 | 模拟
【每日一题Day133】LC2373矩阵中的局部最大值 | 模拟
56 0
|
8月前
【每日一题Day160】LC1092最短公共超序列 | 动态规划
【每日一题Day160】LC1092最短公共超序列 | 动态规划
63 0
【每日一题Day160】LC1092最短公共超序列 | 动态规划
|
8月前
|
vr&ar
【每日一题Day166】LC1053交换一次的先前排列 | 贪心
【每日一题Day166】LC1053交换一次的先前排列 | 贪心
80 1
|
8月前
【每日一题Day358】LC2698求一个整数的惩罚数 | 递归
【每日一题Day358】LC2698求一个整数的惩罚数 | 递归
60 0
|
8月前
【每日一题Day255】LC2679矩阵中的和 | 排序
【每日一题Day255】LC2679矩阵中的和 | 排序
33 0
|
8月前
【每日一题Day165】LC1039多边形三角剖分的最低得分 | 区间dp
【每日一题Day165】LC1039多边形三角剖分的最低得分 | 区间dp
62 0
|
存储
【每日一题Day58】LC1785构成特定和添加的最少元素 | 贪心
思路:首先统计数组nums的和sum,然后计算sum与goal的差target,我们需要向数组中添加最少的元素,使元素的和满足差值,元素的个数即为最终结果,因此每次添加的元素应尽可能最大。由于添加数值的绝对值大小受limit限制,因此添加元素的数值绝对值为limit的个数为Math.abs(target)/limit,如果Math.abs(target)不等于0,那么还需添加一个元素使和等于target
70 1