力扣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;
    }
};
相关推荐
孤狼灬笑4 分钟前
深度学习经典分类(算法分析与案例)
rnn·深度学习·算法·cnn·生成模型·fnn
dragoooon347 分钟前
[优选算法专题四.前缀和——NO.26二维前缀和]
算法
苏小瀚1 小时前
算法---位运算
java·算法
Code小翊1 小时前
归并排序基础理解
数据结构·算法·排序算法
2401_841495642 小时前
【数据结构】基于Floyd算法的最短路径求解
java·数据结构·c++·python·算法··floyd
珊珊而川2 小时前
SAUP 算法
算法
寂静山林2 小时前
UVa 1471 Defense Lines
算法
CHANG_THE_WORLD3 小时前
switch语句在汇编层面的几种优化方式 ,为什么能进行优化
汇编·算法·switch·汇编分析·switch case·switch case 汇编·switch case 语句
山,离天三尺三3 小时前
深度拷贝详解
开发语言·c++·算法
Blossom.1183 小时前
把AI“撒”进农田:基于极值量化与状态机的1KB边缘灌溉决策树
人工智能·python·深度学习·算法·目标检测·决策树·机器学习