编程练习【将找到的值乘以2】

给定一个整数数组nums和一个整数original,从original开始,如果在数组中找到它,就将其乘以2,然后继续查找新的值,直到找不到为止。返回original的最终值。例如,对于nums=[5,3,6,1,12]和original=3,最终返回24。
摘要由CSDN通过智能技术生成

给你一个整数数组 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

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

思路:

使用一个哈希表来记录数组中的数,如果能够找到目标数字,则将数字乘以2,一直到找不到相等的数字。

代码:

public static int findFinalValue(int[] nums, int original) {
		// 初始哈希表
        int[] counts = new int[1001];
        // 哈希表记录数组中出现的数字
        for(int x:nums) {
        	counts[x]++;
        }
        // 如果能在数组中找到,则将original翻倍
        while (original <= 1000 && counts[original] > 0) {
            original *= 2;
        }
        return original;
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值