力扣2578. 最小和分割

题目描述:

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

  • num1num2 直接连起来,得到 num 各数位的一个排列。
    • 换句话说,num1num2 中所有数字出现的次数之和等于 num 中所有数字出现的次数。
  • num1num2 可以包含前导 0 。

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

注意:

  • num 保证没有前导 0 。
  • num1num2 中数位顺序可以与 num 中数位顺序不同。

示例 1:

输入:num = 4325
输出:59
解释:我们可以将 4325 分割成 num1 = 24 和 num2 = 35 ,和为 59 ,59 是最小和。

示例 2:

输入:num = 687
输出:75
解释:我们可以将 687 分割成 num1 = 68 和 num2 = 7 ,和为最优值 75 。

提示:

  • 10 <= num <= 10^9

思路:

这个题很简单,就是把num里面的所有位数全部取出来,然后分给两个数,看怎么组合两个数的和最小。首先,这两个数num1和num2的位数一定相差不能超过1,比如说,如果num是一个四位数,那么num1和num2一定是两个两位数相加,否则就是一个三位数加一个一位数,不利于得到最小和。

而且,要想num1+num2最小,这两个数的各个位数的排序一定是小的在前面。

比如说num=1324,那么1和2是最小的两个数,把他们分别反在num1,num2高位,在安排3、4。

注意这里由于两数相加是相应位数相加,所以对于同一位而言,1+2和2+1没有区别,也就是说13+24与14+23没有区别。

这样一来,直接将num的各个位数从小到大依次安排在num1和num2的高位就OK。

代码:

cpp 复制代码
class Solution {
public:
    int splitNum(int num) {
        vector<int> arr;
        int a=0;
        int b=0;
        while(num){
            int k=num%10;
            arr.push_back(k);
            num/=10;
        }

        sort(arr.begin(),arr.end());
        for(int i=0;i<arr.size();i++){
            if(i%2==0){
                a=a*10+arr[i];
            }else{
                b=b*10+arr[i];
            }
        }
        return a+b;
    }
};
相关推荐
pianmian11 小时前
python数据结构基础(7)
数据结构·算法
考试宝2 小时前
国家宠物美容师职业技能等级评价(高级)理论考试题
经验分享·笔记·职场和发展·学习方法·业界资讯·宠物
好奇龙猫3 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸4 小时前
链表的归并排序
数据结构·算法·链表
jrrz08284 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time4 小时前
golang学习2
算法
面试鸭4 小时前
离谱!买个人信息买到网安公司头上???
java·开发语言·职场和发展
南宫生5 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步6 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝