Leetcode 【2342. 数位和相等数对的最大和】

给你一个下标从 0 开始的数组 nums ,数组中的元素都是 整数。请你选出两个下标 iji != j),且 nums[i] 的数位和 与 nums[j] 的数位和相等。

请你找出所有满足条件的下标 ij ,找出并返回nums[i] + nums[j]可以得到的 最大值

示例 1:

复制代码
输入:nums = [18,43,36,13,7]
输出:54
解释:满足条件的数对 (i, j) 为:
- (0, 2) ,两个数字的数位和都是 9 ,相加得到 18 + 36 = 54 。
- (1, 4) ,两个数字的数位和都是 7 ,相加得到 43 + 7 = 50 。
所以可以获得的最大和是 54 。

示例 2:

复制代码
输入:nums = [10,12,19,14]
输出:-1
解释:不存在满足条件的数对,返回 -1 。

提示:

  • 1 <= nums.length <=
  • 1 <= nums[i] <=

方法:哈希表

看到这么恐怖的数量级,第一想法肯定是暴力行不通,那么就来试试哈希表

首先将数组nums中每个元素的数位和保存在一个新数组中:

python 复制代码
for i in nums:
            str_i = str(i)
            res = 0
            for digit in str_i:
                res += int(digit)
            sum_num.append(res)

这段代码的时间复杂度是O(n)

然后创建字典,key值为当前数位和,当字典中不存在该key值时,dic[key]为nums中的当前元素值,如果字典中存在key值,那么将新的nums元素值append到字典中:

python 复制代码
for i in range(n):
            key = sum_num[i]
            if key not in dic:
                dic[key] = [nums[i]]
            else:
                dic[key].append(nums[i])

最后遍历字典,找出key值对应的value有两个及以上,并且按照降序排列,找出最大和即可:

python 复制代码
for key, numbers in dic.items():
            if len(numbers) >= 2:
                numbers.sort(reverse=True)
                pair_sum = numbers[0] + numbers[1]
                ans = max(ans, pair_sum)

完整代码:

python 复制代码
class Solution:
    def maximumSum(self, nums: List[int]) -> int:
        sum_num = []
        dic={}
        n=len(nums)
        ans=-1
        for i in nums:
            str_i = str(i)
            res = 0
            for digit in str_i:
                res += int(digit)
            sum_num.append(res)

        for i in range(n):
            key = sum_num[i]
            if key not in dic:
                dic[key] = [nums[i]]
            else:
                dic[key].append(nums[i])

        for key, numbers in dic.items():
            if len(numbers) >= 2:
                numbers.sort(reverse=True)
                pair_sum = numbers[0] + numbers[1]
                ans = max(ans, pair_sum)

        return ans

最后,看了灵佬的题解再次震撼我心,附上灵佬题解链接:

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

相关推荐
索迪迈科技1 小时前
Flink Task线程处理模型:Mailbox
java·大数据·开发语言·数据结构·算法·flink
元亓亓亓2 小时前
LeetCode热题100--230. 二叉搜索树中第 K 小的元素--中等
算法·leetcode·职场和发展
草莓熊Lotso2 小时前
《算法闯关指南:优选算法-双指针》--01移动零,02复写零
c语言·c++·经验分享·算法·leetcode
焜昱错眩..3 小时前
代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
算法
焦耳加热7 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn7 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6067 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠10 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油10 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream10 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等