【华为OD机考真题】- 路灯照明(Java)

输入描述

第一行为一个数 N,表示路灯个数:1 <= N <= 100000,

第二行为 N 个空格分割的数,表示路灯的照明半径,1 <= 照明半径。

输出描述

无法照明的区间的长度和。

示例演示
示例1

输入:

复制代码
2
50 50

输出:

复制代码
0

示例2

输入:

复制代码
4
50 70 20 70

输出:

复制代码
20

示例说明: 50+70>100,70+20<100,20+70<100,所以有 两个未要盖的区间,总里程为 10+10=20。

注:这里需要注意照明半径大于100时,需要判断当前灯半径是否大于前一个灯半径-100,如果是大于则将当前灯半径传给下一个灯,如果小于则,将前一个灯半径-100传给下一个灯。

java 复制代码
package odTest;

import java.util.Arrays;
import java.util.Scanner;

public class lightQuestion {
	static int sum = 0;
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		int num = Integer.parseInt(scanner.nextLine());
		
		int[] lightCoverArea = Arrays.stream(scanner.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();
		
		judgeUnCover(num,lightCoverArea,lightCoverArea[0],1);
		System.out.println(sum);
	}

	private static void judgeUnCover(int num, int[] lightCoverArea, int preVal,int index) {
		// TODO Auto-generated method stub
		if(index==num) {
			return;
		}
		if(preVal+lightCoverArea[index]<100) {
//			System.out.println(preVal);
			sum = sum+100-(preVal+lightCoverArea[index]);
//			System.out.println(sum);
		}
		
		//判断当前照明半径,传给下一个灯
		if(preVal<100&&lightCoverArea[index]<100) {
//			System.out.println(1);
			preVal=lightCoverArea[index];
		}else if(preVal>100&&lightCoverArea[index]+100<preVal) {
			preVal=preVal-100;
		}else if(preVal>100&&lightCoverArea[index]+100>preVal) {
			preVal=lightCoverArea[index];
		}else if(preVal<100&&lightCoverArea[index]>100) {
			preVal=lightCoverArea[index];
		}
		judgeUnCover(num,lightCoverArea,preVal,index+1);
	}

}
相关推荐
练习时长一年2 分钟前
AopAutoConfiguration源码阅读
java·spring boot·intellij-idea
源码宝1 小时前
【智慧工地源码】智慧工地云平台系统,涵盖安全、质量、环境、人员和设备五大管理模块,实现实时监控、智能预警和数据分析。
java·大数据·spring cloud·数据分析·源码·智慧工地·云平台
David爱编程2 小时前
面试必问!线程生命周期与状态转换详解
java·后端
LKAI.3 小时前
传统方式部署(RuoYi-Cloud)微服务
java·linux·前端·后端·微服务·node.js·ruoyi
HeyZoeHey3 小时前
Mybatis执行sql流程(一)
java·sql·mybatis
2301_793086873 小时前
SpringCloud 07 微服务网关
java·spring cloud·微服务
柳贯一(逆流河版)4 小时前
Spring 三级缓存:破解循环依赖的底层密码
java·spring·缓存·bean的循环依赖
该用户已不存在5 小时前
OpenJDK、Temurin、GraalVM...到底该装哪个?
java·后端
TT哇6 小时前
@[TOC](计算机是如何⼯作的) JavaEE==网站开发
java·redis·java-ee
Tina学编程6 小时前
48Days-Day19 | ISBN号,kotori和迷宫,矩阵最长递增路径
java·算法