735.小行星碰撞

题目:给定一个整数数组 asteroids,表示在同一行的小行星。

对于数组中的每一个元素,其绝对值表示小行星的大小,正负表示小行星的移动方向(正表示向右移动,负表示向左移动)。每一颗小行星以相同的速度移动。

找出碰撞后剩下的所有小行星。碰撞规则:两个小行星相互碰撞,较小的小行星会爆炸。如果两颗小行星大小相同,则两颗小行星都会爆炸。两颗移动方向相同的小行星,永远不会发生碰撞。

解题思路:使用栈st 模拟行星碰撞,从左往右遍历行星数组asteroids,当我们遍历到行星aster时,使用变量alive 记录行星aster 是否还存在。

当行星 aster 存在且 aster

class Solution {
    public int[] asteroidCollision(int[] asteroids) {
        Deque<Integer> stack = new ArrayDeque<Integer>();
        for (int aster : asteroids) {
            boolean alive = true;
            while (alive && aster < 0 && !stack.isEmpty() && stack.peek() > 0) {
                alive = stack.peek() < -aster; // aster 是否存在
                if (stack.peek() <= -aster) {  // 栈顶行星爆炸
                    stack.pop();
                }
            }
            if (alive) {
                stack.push(aster);
            }
        }
        int size = stack.size();
        int[] ans = new int[size];
        for (int i = size - 1; i >= 0; i--) {
            ans[i] = stack.pop();
        }
        return ans;
    }
}

相关推荐

  1. 735. 小行星碰撞

    2024-04-07 15:22:05       35 阅读
  2. unity车辆碰撞检测

    2024-04-07 15:22:05       107 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-07 15:22:05       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-07 15:22:05       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-07 15:22:05       87 阅读
  4. Python语言-面向对象

    2024-04-07 15:22:05       96 阅读

热门阅读

  1. C++初级---模板初阶

    2024-04-07 15:22:05       41 阅读
  2. 多线程(36)AtomicStampedReference

    2024-04-07 15:22:05       42 阅读
  3. 上升Chrome安装Vue插件vue-devtools

    2024-04-07 15:22:05       31 阅读
  4. 基于开源软件构建存储解决方案的思考

    2024-04-07 15:22:05       37 阅读
  5. [Qt]解析moc文件

    2024-04-07 15:22:05       25 阅读
  6. C/C++ 查泄漏得一些方法

    2024-04-07 15:22:05       33 阅读