入门力扣自学笔记278 C++ (题目编号:2605)

2605. 从两个数字数组里生成最小数字

题目:

给你两个只包含 1 到 9 之间数字的数组 nums1nums2 ,每个数组中的元素 互不相同 ,请你返回 最小 的数字,两个数组都 至少 包含这个数字的某个数位。


示例 1:

复制代码
输入:nums1 = [4,1,3], nums2 = [5,7]
输出:15
解释:数字 15 的数位 1 在 nums1 中出现,数位 5 在 nums2 中出现。15 是我们能得到的最小数字。

示例 2:

复制代码
输入:nums1 = [3,5,2,6], nums2 = [3,1,7]
输出:3
解释:数字 3 的数位 3 在两个数组中都出现了。

提示:

  • 1 <= nums1.length, nums2.length <= 9
  • 1 <= nums1[i], nums2[i] <= 9
  • 每个数组中,元素 互不相同

思路:

首先,建立一个哈希表,并且遍历nums1来更新哈希表。

其次,我们遍历nums2,如果两个容器存在相同的元素,那么返回最小的相同元素结果即可。

最后,如果不存在相同元素,那么对两个vector容器进行排序,找到两个容器的最小元素,并且构成最小的两位数即可。


代码:

cpp 复制代码
class Solution {
public:
    int minNumber(vector<int>& nums1, vector<int>& nums2) {
        unordered_map<int,int> hash;
        for(auto &i : nums1)
            ++hash[i];
        int ans = 100;
        for(auto &i :nums2)
            if(hash.find(i) != hash.end())
                ans = min(ans,i);
        sort(nums1.begin(),nums1.end());
        sort(nums2.begin(),nums2.end());
        int tmp = nums1[0];
        ans = min(tmp * 10 + nums2[0],ans);
        tmp = nums2[0];
        ans = min(tmp * 10 + nums1[0],ans);
        return ans;
    }
};
相关推荐
sprintzer16 分钟前
1.6-1.15力扣数学刷题
算法·leetcode·职场和发展
jiang_bluetooth18 分钟前
channel sounding基于探测序列的时延和相位差算法
算法·蓝牙测距·channel sound·gfsk·蓝牙6.0
玖釉-18 分钟前
[Vulkan 学习之路] 16 - 最终章:渲染循环与同步 (Rendering & Presentation)
c++·windows·图形渲染
踩坑记录25 分钟前
leetcode hot100 53.最大子数组和 动态规划 medium
leetcode·动态规划
狗狗学不会27 分钟前
Pybind11 封装 RK3588 全流程服务:Python 写逻辑,C++ 跑并发,性能起飞!
c++·人工智能·python·目标检测
DYS_房东的猫33 分钟前
《 C++ 零基础入门教程》第10章:C++20 核心特性 —— 编写更现代、更优雅的 C++
java·c++·c++20
地平线开发者34 分钟前
征程 6 算法工具链 | PTQ 深度使用指南
算法·自动驾驶
Howrun7771 小时前
虚幻引擎_AController_APlayerController_AAIController
开发语言·c++·游戏引擎·虚幻
小林rr1 小时前
深入探索 C++:现代特性、工程实践与性能优化全解
java·c++·性能优化
Xの哲學1 小时前
Linux 软中断深度剖析: 从设计思想到实战调试
linux·网络·算法·架构·边缘计算