当前位置: 首页 > news >正文

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

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

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

令两次对 num 的操作得到的结果分别为 a 和 b 。

请你返回 a 和 b 的 最大差值 。

注意,新的整数(a 或 b必须不能 含有前导 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.

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;
}

http://www.dtcms.com/a/251644.html

相关文章:

  • PCB设计教程【大师篇】stm32开发板PCB布线(电源部分)
  • 基于C_PSO与BP神经网络回归模型的特征选择方法研究(Python实现)
  • Nginx超快速入门
  • Vite:下一代前端构建工具的革命性突破
  • 对于数据库触发器自动执行的理解
  • 使用VSCode开发MCU,FreeRTOS进Hard_Fault调试
  • idea2024使用卡顿
  • golang-linux环境配置
  • LeetCode 1385.两个数组间的距离值
  • 基于深度强化学习的智能机器人路径规划系统:技术与实践
  • 车载软件架构 --- 汽车中央控制单元HPC软件架构方案实例
  • 用于汽车毫米波雷达的四维高分辨率点云图像
  • 【MPC】模型预测控制笔记 (3):无约束输出反馈MPC
  • Seelen UI 是Windows 桌面开发
  • 深度学习进化史:从神经元的诞生到万亿参数的觉醒
  • 电阻篇---上拉电阻的取值
  • Java垃圾回收机制
  • 1.17 模板引擎EJS
  • 如何可视化机器学习模型:从线性回归到神经网络
  • 学习日记-day30-6.15
  • 山东大学软件学院创新项目实训开发日志——第十七周(二)
  • 手写muduo网络库(九):TcpConnection
  • 如何使用configure脚本安装PBS
  • 图形编辑器基于Paper.js教程29:基于图层的所有矢量图元的填充规则实现
  • 组策略关闭 Windows 防火墙指南(企业版/专业版)
  • SpringMVC系列(一)(介绍,简单应用以及路径位置通配符)
  • 机器学习实验报告5-K-means 算法
  • Linux--存储系统探秘:从块设备到inode
  • 影视剧学经典系列-梁祝-陶渊明《感士不遇赋并序》
  • Appium+python自动化(二十三)- Monkeyrunner与Monkey