leetcode 2566. 替换一个数字后的最大差值 简单

给你一个整数 num 。你知道 Danny Mittal 会偷偷将 09 中的一个数字 替换 成另一个数字。

请你返回将 num恰好一个 数字进行替换后,得到的最大值和最小值的差为多少。

注意:

  • 当 Danny 将一个数字 d1 替换成另一个数字 d2 时,Danny 需要将 nums 中所有 d1 都替换成 d2
  • Danny 可以将一个数字替换成它自己,也就是说 num 可以不变。
  • Danny 可以将数字分别替换成两个不同的数字分别得到最大值和最小值。
  • 替换后得到的数字可以包含前导 0 。
  • Danny Mittal 获得周赛 326 前 10 名,让我们恭喜他。

示例 1:

复制代码
输入:num = 11891
输出:99009
解释:
为了得到最大值,我们将数字 1 替换成数字 9 ,得到 99899 。
为了得到最小值,我们将数字 1 替换成数字 0 ,得到 890 。
两个数字的差值为 99009 。

示例 2:

复制代码
输入:num = 90
输出:99
解释:
可以得到的最大值是 99(将 0 替换成 9),最小值是 0(将 9 替换成 0)。
所以我们得到 99 。

提示:

  • 1 <= num <= 10^8

分析:用一个数组存储 num 的每位数字。之后从高位向低位检查,将第一个不是 9 的数字都改成 9,得到最大值;将第一个不是 0 的数字改为 0,得到最小值。最后相减得到答案。

cpp 复制代码
int minMaxDifference(int num) {
    int cnt[10]={0},cnt_max=0,cnt_min=0;
    int temp=num,t=0;
    while(temp)
        cnt[t++]=temp%10,temp/=10;
    int ind_max=-1,ind_min=-1;
    for(int i=t-1;i>=0;--i)
    {
        if(cnt[i]!=9&&ind_max==-1)ind_max=cnt[i];
        if(cnt[i]!=0&&ind_min==-1)ind_min=cnt[i];

        if(cnt[i]==ind_max)cnt_max=cnt_max*10+9;
        else cnt_max=cnt_max*10+cnt[i];

        if(cnt[i]==ind_min)cnt_min=cnt_min*10+0;
        else cnt_min=cnt_min*10+cnt[i];
    }

    return cnt_max-cnt_min;
    
}
相关推荐
多米Domi01139 分钟前
0x3f 第49天 面向实习的八股背诵第六天 过了一遍JVM的知识点,看了相关视频讲解JVM内存,垃圾清理,买了plus,稍微看了点确定一下方向
jvm·数据结构·python·算法·leetcode
VT.馒头15 小时前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript
毅炼17 小时前
hot100打卡——day17
java·数据结构·算法·leetcode·深度优先
Tisfy17 小时前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
草履虫建模18 小时前
力扣算法 121. 买卖股票的最佳时机
算法·leetcode·职场和发展·贪心算法·动态规划·一次遍历
爱尔兰极光18 小时前
LeetCode--有序数组的平方
算法·leetcode·职场和发展
haluhalu.19 小时前
LeetCode---基础算法刷题指南
数据结构·算法·leetcode
iAkuya19 小时前
(leetcode)力扣100 58组合总和(回溯)
算法·leetcode·职场和发展
爱尔兰极光19 小时前
LeetCode--移除元素
算法·leetcode·职场和发展
苦藤新鸡20 小时前
51.课程表(拓扑排序)-leetcode207
数据结构·算法·leetcode·bfs