腾讯一面之气球游戏

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

题目原文

小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

目录
相关文章
【字节跳动】跳跃游戏
【字节跳动】跳跃游戏
|
Python
python实现一个简单的消消乐游戏
实现一个简单的消消乐游戏可以是一个有趣的编程项目。下面是一个使用Python和Pygame库来创建消消乐游戏的基本步骤
473 0
|
6月前
|
前端开发 C语言 C++
每周一坑--打飞机游戏
每周一坑--打飞机游戏
84.提高游戏的颜值3
84.提高游戏的颜值3
119 0
84.提高游戏的颜值3
|
存储 前端开发 开发者
「用前端重返童年🥤」为黑神话悟空定制红白机版游戏开始动画
「用前端重返童年🥤」为黑神话悟空定制红白机版游戏开始动画
287 0
|
Android开发 芯片 iOS开发
命运多舛的游戏手机还能等到它的春天吗?
从标题就知道我们今天要聊一聊游戏手机,就目前来看,游戏手机还只是活在小众圈子里。即便ROG在最新发布的手机里做出了不少思考和努力,也无济于事。为什么这么说,就听我细细道来。
163 0
命运多舛的游戏手机还能等到它的春天吗?
|
边缘计算 人工智能 JavaScript
2021爱智先行者—我的第一个爱智小游戏之切方块(01)
2021爱智先行者—我的第一个爱智小游戏之切方块
239 0
2021爱智先行者—我的第一个爱智小游戏之切方块(01)
|
数据安全/隐私保护
2021爱智先行者—我的第一个爱智小游戏之切方块(02)
2021爱智先行者—我的第一个爱智小游戏之切方块
131 0
2021爱智先行者—我的第一个爱智小游戏之切方块(02)
星空发现图(仿蜗牛梦话圈)
最终效果       直接使用 继承 BaseAdapter 实现onCreateCenter(ViewGroup parent) onCreateChild(ViewGroup parent, T t)方法设置中心View,子View.
1043 1