荒岛逃生游戏

题目描述

一个荒岛上有若干人,岛上只有一条路通往岛屿两端的港口,大家需要逃往两端的港口才可逃生。

假定每个人移动的速度一样,且只可选择向左或向右逃生。

若两个人相遇,则进行决斗,战斗力强的能够活下来,并损失掉与对方相同的战斗力;若战斗力相同,则两人同归于尽。

输入描述

给定一行非 0 整数数组,元素个数不超过30000;

正负表示逃生方向(正表示向右逃生,负表示向左逃生),绝对值表示战斗力,越左边的数字表示里左边港口越近,逃生方向相同的人永远不会发生决斗。

输出描述

能够逃生的人总数,没有人逃生输出0,输入异常时输出-1。

示例1

输入

5 10 8 -8 -5

输出

2

说明

第3个人和第4个人同归于尽,第2个人杀死第5个人并剩余5战斗力,第1个人没有遇到敌人。

解题思路

从头开始逐个读取 向右移动的数,遇到向左移动的数,后读取的数需要先和向左移动的数进行战斗,战斗人员是一个先进后出的顺序,考虑使用栈这个结构进行处理

源码 Java

java 复制代码
public class EscapeIsland {

	static Input input ;
	static {
		input = new Input("5 10 8 -8 -5");
	}

	public static void main(String[] args) {
		Stack<Integer> right = new Stack<>();
		Stack<Integer> left = new Stack<>();
		String[] split = input.nextLine().split(" ");
		for (int i = 0; i < split.length; i++) {
			int val = Integer.parseInt(split[i]) ;
			if (val == 0) {
				System.out.println(-1);
				return;
			}
			if (val > 0) {
				right.push(val);
			} else {

				int power = val;

				while (!right.isEmpty() && power < 0) {
					int r = right.pop();
					power += r;
				}
				if (power > 0) {
					right.push(power);
				} else if(power < 0) {
					left.push(power);
				}
			}
		}
		System.out.println(right.size() + left.size());
	}

}
相关推荐
鱼很腾apoc16 小时前
【学习篇】第20期 超详解 C++ 多态:从语法规则到底层原理
java·c语言·开发语言·c++·学习·算法·青少年编程
blackorbird17 小时前
M4 MacBook Air外接RTX 5090实现3A游戏与AI加速
人工智能·游戏
小许同学记录成长18 小时前
三维重建技术文档
算法·无人机
小O的算法实验室19 小时前
2026年ASOC,基于多目标优化去噪双存档进化算法+路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
2601_9545267520 小时前
逆向解析Temu底层动销算法:基于API高并发轮询与全域存量透视的自动化架构重构
算法·架构·自动化
Σίσυφος190020 小时前
数据标准化(拟合的时候使用非常重要)
人工智能·算法
knight_9___20 小时前
大模型project面试7
人工智能·python·算法·面试·大模型·agent
Android出海21 小时前
5月合规风暴眼:Google Play权限大限与欧盟游戏监管新棋局
人工智能·游戏·google play·谷歌开发者·android开发者·google开发者·google play开发者
STDD21 小时前
Teeworlds / DDNet 服务器搭建:经典 2D 竞技平台游戏
服务器·游戏·github