腾讯一面之气球游戏

简介: 腾讯一面之气球游戏

题目原文

小Q在进行射击气球的游戏,如果小Q在连续T枪中打爆了所有颜色的气球,将得到一只QQ公仔作为奖励。(每种颜色的球至少被打爆一只)。

这个游戏中有m种不同颜色的气球,编号1到m。

小Q一共有n发子弹,然后连续开了n枪。

小Q想知道在这n枪中,打爆所有颜色的气球最少用了连续几枪?

原始连接

思路与解答

这个题目一开始是琢磨题目了半天,后面自己整理了一下,基本就是不断开枪,开枪之后数字就代表颜色编号,因为颜色可以重复的,题目是问里面连续中枪的时候可以覆盖全部的颜色。

直观上来说其实就是需要连续的一段数字里面可以保证包含所有的颜色,图中两个箭头都满足,但是我们需要的是最短的射击次数,所以后面的才是要的答案。

这种两边夹住一部分结果进行判断的操作其实都是窗口的思想。

我们可以定义两个指针,左边和右边,两个指针都是递增的,

1、当我们移动右边边的指针的时候保证窗口内可以包含所有元素,当满足条件的时候停止

2、我们移动左边指针,意味着窗口内元素会减少,当我们减少元素的时候,不断判断是否窗口内还是满足全部的元素

3、窗口内的元素个数我们计数,在窗口里面则每出现一次就+1,移除的时候则减一,当窗口里面每次移除的时候我们更新路径

代码示例

 public static int search(int[] nums, int colorCount) {
        int left = 0;
        int right = 0;
        int[] colorCnts = new int[colorCount + 1]; //记录窗口内颜色的个数,因为颜色不会从0开始,所以数组个数+1
        int curColor = colorCount;
        Arrays.fill(colorCnts, 1);
        colorCnts[0] = 0;
        int window = Integer.MAX_VALUE;
        while (right < nums.length) {
            int rightNumber = nums[right];
            right++;
            if (colorCnts[rightNumber]-- > 0) {
                curColor--;
            }
            while (curColor == 0) {
                if (right - left < window) {
                    window = right - left;
                }
                int leftNumber = nums[left];
                left++;
                if (colorCnts[leftNumber]++ == 0) {
                    curColor++;
                }
            }
        }
        return window == Integer.MAX_VALUE ? -1 : window;
    }

代码说明,我们提前把窗口内颜色对应的数字都做标记,里面有1的就是存在的标记

当right往右边移动时,颜色进入窗口,我们把颜色数量往下减,直到数量是0的时候,说明全部颜色都覆盖了,此时移动左边指针,颜色出窗口的时候颜色标记+1

目录
相关文章
|
10天前
|
编解码 定位技术 vr&ar
NETALAND惊艳上线,Paraverse平行云助力元宇宙大玩家网易闪亮登场
网易传媒旗下全新泛娱乐空间NETALAND于2023年5月上线,融合电影级场景与趣味互动,提供沉浸式元宇宙体验。通过与平行云合作,NETALAND实现了轻量化社交、全地图飞行及丰富的定制化功能,支持用户在五大风格场景中自由探索。LarkXR实时云渲染技术确保了流畅的交互体验,并助力采集宝贵的用户行为数据,推动元宇宙内容创新。
|
6月前
|
开发者
【植物大战僵尸杂交版】致敬传奇游戏玩家——一个普通人的六年坚持
【植物大战僵尸杂交版】致敬传奇游戏玩家——一个普通人的六年坚持
|
8月前
|
存储 安全 vr&ar
【周末闲谈】VR新视界,“眼”见未来
【周末闲谈】VR新视界,“眼”见未来
96 0
|
存储 前端开发 开发者
「用前端重返童年🥤」为黑神话悟空定制红白机版游戏开始动画
「用前端重返童年🥤」为黑神话悟空定制红白机版游戏开始动画
296 0
|
Web App开发 程序员 Android开发
腾讯游戏帝国之发轫2003
2003年,新浪、搜狐、网易,分别实现了上市以来首次全年盈利,起点中文网开始探索付费阅读,远在大洋彼岸一个名为Andy Rubin的工程师,创办了Android,开始启动下一代智能手机的开发。
298 0
腾讯游戏帝国之发轫2003
|
Android开发 芯片 iOS开发
命运多舛的游戏手机还能等到它的春天吗?
从标题就知道我们今天要聊一聊游戏手机,就目前来看,游戏手机还只是活在小众圈子里。即便ROG在最新发布的手机里做出了不少思考和努力,也无济于事。为什么这么说,就听我细细道来。
172 0
命运多舛的游戏手机还能等到它的春天吗?