leetcode 1432. 改变一个整数能得到的最大差值 中等

给你一个整数 num 。你可以对它进行以下步骤共计 两次

  • 选择一个数字 x (0 <= x <= 9).
  • 选择另一个数字 y (0 <= y <= 9) 。数字 y 可以等于 x
  • num 中所有出现 x 的数位都用 y 替换。

令两次对 num 的操作得到的结果分别为 ab

请你返回 ab最大差值

注意,新的整数(ab必须不能 含有前导 0,并且 0。

示例 1:

复制代码
输入:num = 555
输出:888
解释:第一次选择 x = 5 且 y = 9 ,并把得到的新数字保存在 a 中。
第二次选择 x = 5 且 y = 1 ,并把得到的新数字保存在 b 中。
现在,我们有 a = 999 和 b = 111 ,最大差值为 888

示例 2:

复制代码
输入:num = 9
输出:8
解释:第一次选择 x = 9 且 y = 9 ,并把得到的新数字保存在 a 中。
第二次选择 x = 9 且 y = 1 ,并把得到的新数字保存在 b 中。
现在,我们有 a = 9 和 b = 1 ,最大差值为 8

示例 3:

复制代码
输入:num = 123456
输出:820000

示例 4:

复制代码
输入:num = 10000
输出:80000

示例 5:

复制代码
输入:num = 9288
输出:8700

提示:

  • 1 <= num <= 10^8

分析:新数字最大,则把第一个非 9 的数字全部变成 9;新数字最小,如果最高位不是 1,则把最高位对应的所有数字全部变成 1,否则找到第一个不为 1 和 0 的数字,把出现的所有这个数字都变成 0.

cpp 复制代码
int maxDiff(int num) {
    int cnt[10]={0},cnt_max=-1,cnt_min=-1;
    int temp=num,t=0;
    while(temp)cnt[t++]=temp%10,temp/=10;

    for(int i=t-1;i>=0;--i)
    {
        if(cnt[i]!=9&&cnt_max==-1)cnt_max=cnt[i];

        if(cnt_min==-1)
        {
            if(cnt[i]==1)
            {
                if(cnt[t-1]==1)continue;
                else cnt_min=cnt[i];
            }
            else if(cnt[i])cnt_min=cnt[i];
        }

        if(cnt_max!=-1&&cnt_min!=-1)break;
    }

    int val_max=0,val_min=0;
    for(int i=t-1;i>=0;--i)
    {
        if(cnt_max!=-1)
        {
            if(cnt[i]==cnt_max)val_max=val_max*10+9;
            else val_max=val_max*10+cnt[i];
        }
        
        if(cnt_min!=-1)
        {
            if(cnt[i]==cnt_min)
            {
                if(cnt[t-1]!=cnt_min)val_min=val_min*10+0;
                else val_min=val_min*10+1;
            }
            else val_min=val_min*10+cnt[i];
        }
    }

    if(cnt_max==-1)val_max=num;
    if(cnt_min==-1)val_min=num;

    return val_max-val_min;
}
相关推荐
elseif12322 分钟前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
偷吃的耗子34 分钟前
【CNN算法理解】:卷积神经网络 (CNN) 数值计算与传播机制
人工智能·算法·cnn
徐小夕@趣谈前端43 分钟前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
问好眼1 小时前
【信息学奥赛一本通】1275:【例9.19】乘积最大
c++·算法·动态规划·信息学奥赛
Daydream.V1 小时前
逻辑回归实例问题解决(LogisticRegression)
算法·机器学习·逻辑回归
代码无bug抓狂人1 小时前
C语言之表达式括号匹配
c语言·开发语言·算法
不穿格子的程序员1 小时前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
学历真的很重要1 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
Nebula_g1 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
rit84324992 小时前
基于MATLAB的环境障碍模型构建与蚁群算法路径规划实现
开发语言·算法·matlab