华为OD真题--荒岛求生--带答案

  1. 华为OD机考题 + 答案

2023华为OD统一考试(A+B卷)题库清单-带答案(持续更新)

2023年华为OD真题机考题库大全-带答案(持续更新)

  1. 面试题

一手真实java面试题:2023年各大公司java面试真题汇总--持续更新

  1. 技术知识

java后端技术汇总 + 中间件 + 架构思想

有一个荒岛,只有左右两个港口,只有一座桥连接这两个港口,现在有一群人需要从两个港口逃生,有的人往右逃生,有的往左逃生,如果两个人相遇,则PK,体力值大的能够打赢体力值小的,体力值相同则同归干尽,赢的人才能继续往前逃生,并减少相应的体力

输入描述

一行非 0 整数,用空格隔开,正数代表向右逃生,负数代表向左逃生

输出描述

最终能够逃生的人数

示例1:

输入

5 10 8 -8 -5

输出

2

说明

8与-8 相遇,同归于尽,10 遇到-5,打赢并减少五点体力,最终逃生的为5,5,均从右侧港口逃生,输出2

复制代码
public class IslandSurvival {
    //5 10 8 -8 -5
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        List<Integer> power = Arrays.stream(sc.nextLine().split(" ")).map(Integer::parseInt).collect(Collectors.toList());
        List<Integer> right = new ArrayList<>();
        List<Integer> left = new ArrayList<>();

        //先将左右方向的人区分
        for (int i = 0; i < power.size(); i++){
            if (power.get(i) > 0){
                right.add(power.get(i));
            }else {
                left.add(power.get(i));
            }
        }
        int exit = fight(left,right);
        System.out.println(exit);
    }

    public static int fight(List<Integer> l,List<Integer> r){
        int exit = 0;
        //用个左右双指针
        int left = 0;
        int right = r.size() - 1;

        while (left < l.size() && right >= 0){
            //体力绝对值不相等,就会有一方能逃离
            //最最左边的跟左右边的人比
            if (Math.abs(l.get(left)) != Math.abs(r.get(right))){
                exit++;
            }
            left++;
            right--;
        }
        //左右方向的有剩余的没有参与战斗的人员
        exit +=  (l.size() -1)-(left - 1);
        exit +=  (right + 1);
        return exit;
    }

}
相关推荐
枣伊吕波5 分钟前
五十三、bean的管理-bean的获取、bean的作用域、第三方bean
java·开发语言
啦工作呢17 分钟前
Sass:CSS 预处理器
开发语言·后端·rust
大鱼七成饱21 分钟前
Rust工具不顺手?VSCode一站式丝滑配置
后端
37手游后端团队28 分钟前
如何利用cursor高效重构代码
人工智能·后端
豆豆·丁30 分钟前
kettle 执行java脚本生成SQL
java·开发语言·数据库
青云交31 分钟前
Java 大视界 -- Java 大数据机器学习模型在金融产品创新与客户需求匹配中的实战应用(417)
java·大数据·金融机器学习·客户需求匹配·产品创新·安居组合贷·合规审计
吹晚风吧33 分钟前
线程安全之《Sychronized的八锁案例》
java·开发语言··sychronized
超级大只老咪37 分钟前
编程竞赛高频考点
java·c语言·开发语言·c++·python
IT_陈寒39 分钟前
SpringBoot 性能优化的 7 个冷门技巧,让你的应用快如闪电!
前端·人工智能·后端
Haooog40 分钟前
111.二叉树的最小深度(二叉树算法题)
java·数据结构·算法·二叉树