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),我们可以依次处理各个位数,从千位到个位。
相关推荐
用户50408278583912 分钟前
1. RAG 权威指南:从本地实现到生产级优化的全面实践
算法
Python×CATIA工业智造1 小时前
详细页智能解析算法:洞悉海量页面数据的核心技术
爬虫·算法·pycharm
无聊的小坏坏2 小时前
力扣 239 题:滑动窗口最大值的两种高效解法
c++·算法·leetcode
黎明smaly2 小时前
【排序】插入排序
c语言·开发语言·数据结构·c++·算法·排序算法
YuTaoShao2 小时前
【LeetCode 热题 100】206. 反转链表——(解法一)值翻转
算法·leetcode·链表
YuTaoShao3 小时前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
CCF_NOI.3 小时前
(普及−)B3629 吃冰棍——二分/模拟
数据结构·c++·算法
运器1233 小时前
【一起来学AI大模型】支持向量机(SVM):核心算法深度解析
大数据·人工智能·算法·机器学习·支持向量机·ai·ai编程
Zedthm4 小时前
LeetCode1004. 最大连续1的个数 III
java·算法·leetcode
神的孩子都在歌唱4 小时前
3423. 循环数组中相邻元素的最大差值 — day97
java·数据结构·算法