欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

LeetCode5993.将找到的值乘以2

时间:2023-06-06
文章目录

1、题目2、解题 1、题目

给你一个整数数组 nums ,另给你一个整数 original ,这是需要在 nums 中搜索的第一个数字。

接下来,你需要按下述步骤操作:

如果在 nums 中找到 original ,将 original 乘以 2 ,得到新 original(即,令 original = 2 * original)。否则,停止这一过程。只要能在数组中找到新 original ,就对新 original 继续 重复 这一过程。

返回 original 的 最终 值。

示例 1:输入:nums = [5,3,6,1,12], original = 3输出:24解释: - 3 能在 nums 中找到。3 * 2 = 6 。- 6 能在 nums 中找到。6 * 2 = 12 。- 12 能在 nums 中找到。12 * 2 = 24 。- 24 不能在 nums 中找到。因此,返回 24 。示例 2:输入:nums = [2,7,9], original = 4输出:4解释:- 4 不能在 nums 中找到。因此,返回 4 。 提示:1 <= nums.length <= 10001 <= nums[i], original <= 1000

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/keep-multiplying-found-values-by-two
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2、解题

按题意模拟

class Solution: def findFinalValue(self, nums: List[int], original: int) -> int: s = set(nums) while original in s: original <<= 1 return original

36 ms 15.1 MB Python3


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。