3270.求出数字答案题解

3270.求出数字答案

1.1、题目描述

给你三个 整数 num1num2num3 。数字 num1num2num3 的数字答案 key 是一个四位数,定义如下:

  • 一开始,如果有数字 少于 四位数,给它补 前导 0
  • 答案 key 的第 i 个数位(1 <= i <= 4)为 num1num2num3i 个数位中的 最小 值。

请你返回三个数字 没有 前导 0 的数字答案。

1.2、代码实现

下面是这个问题的 C++ 代码实现:

复制代码
class Solution {
public:
    int generateKey(int num1, int num2, int num3) {
        int ret = 0;       // 最终结果 key
        int tmp = 1000;    // 用于定位当前位的除数
        
        for (int i = 0; i < 4; i++) {
            // 将当前的 key 向左移一位
            ret *= 10;
            // 获取 num1, num2, num3 当前位的值,找出最小值并添加到 key
            ret += min(num1 / tmp % 10, min(num2 / tmp % 10, num3 / tmp % 10));
            // 更新除数,以便获取下一位
            tmp /= 10;
        }
        
        return ret;
    }
};

1.3、代码详解

  1. 变量定义
    • ret:存储最终生成的 key,初始值为 0。
    • tmp:用于定位当前处理的数字位,从千位开始,初始值为 1000
  2. 循环构造 key
    • 使用一个四次循环,通过不断将 ret 向左移一位(乘以 10),来为 key 逐位赋值。
    • 通过表达式 num1 / tmp % 10,我们可以提取当前位的数字值。接着使用 min 函数找到 num1num2num3 当前位的最小值,并将其加入到 key 中。
    • 最后,通过更新 tmp(除以 10),我们可以依次处理各个位数,从千位到个位。
相关推荐
追随者永远是胜利者4 小时前
(LeetCode-Hot100)20. 有效的括号
java·算法·leetcode·职场和发展·go
瓦特what?5 小时前
快 速 排 序
数据结构·算法·排序算法
niuniudengdeng5 小时前
基于时序上下文编码的端到端无文本依赖语音分词模型
人工智能·数学·算法·概率论
hetao17338375 小时前
2026-02-13~16 hetao1733837 的刷题记录
c++·算法
你的冰西瓜7 小时前
2026春晚魔术揭秘——变魔法为物理
算法
忘梓.7 小时前
解锁动态规划的奥秘:从零到精通的创新思维解析(10)
c++·算法·动态规划·代理模式
foolish..7 小时前
动态规划笔记
笔记·算法·动态规划
消失的dk7 小时前
算法---动态规划
算法·动态规划
羑悻的小杀马特7 小时前
【动态规划篇】欣赏概率论与镜像法融合下,别出心裁探索解答括号序列问题
c++·算法·蓝桥杯·动态规划·镜像·洛谷·空隙法
绍兴贝贝7 小时前
代码随想录算法训练营第四十六天|LC647.回文子串|LC516.最长回文子序列|动态规划总结
数据结构·人工智能·python·算法·动态规划·力扣