Atcoder ABC339 C - Perfect Bus

Perfect Bus(完美的公交车)

时间限制:2s 内存限制:1024MB

【原题地址】

所有图片源自Atcoder,题目译文源自脚本Atcoder Better!

点击此处跳转至原题

【问题描述】

【输入格式】


【输出格式】

【样例1】

【样例输入1】

java 复制代码
4
3 -5 7 -4

【样例输出1】

java 复制代码
3

【样例说明1】

【样例2】

【样例输入2】

java 复制代码
5
0 0 0 0 0

【样例输出2】

java 复制代码
0

【解题思路】

老汉使用到的是贪心的解题方式

本题是求最终车上的最少人数,因为车上人数不可能为负数,所以变量存在于发车时车上原有人数,条件允许的情况下原有人数为0时肯定是最小值,但是为了满足不为负这个条件,我们需要通过一个合适的原有人数进行维护。

用一个变量sum存储每个阶段车上对比原发车时的人数变化量,变量min用于存储其中变化量最低的值,当处于这个阶段都满足不为负数时,其他阶段也必然满足,最后根据sum和min求得最终答案。

代码注释有详细过程

【代码】

java 复制代码
package ABC339_C_PerfectBus;

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		long[] a = new long[n + 1];
		// 获取人流变化的总和,即最终总变化量
		long sum = 0;
		// 存放人流变化量总和最小阶段的值
		long min = Long.MAX_VALUE;
		for (int i = 1; i <= n; i++) {
			a[i] = scan.nextLong();
			sum += a[i];
			// 获取最小值
			min = Math.min(min, sum);
		}
		// 当最小阶段值为负数时,则代表开始时车上最少要有-min人
		if (min < 0) {
			System.out.println(sum - min);
		} else {
			// 不为负数时,代表开始时车上最少0人
			System.out.println(sum);
		}
		scan.close();
	}
}
相关推荐
赴生-36 分钟前
C++进阶 异常
开发语言·c++
黄毛火烧雪下1 小时前
Java 核心知识点总结(一)
java·开发语言
其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码与防御技术理论题库
开发语言·网络·安全·网络安全·软件安全·软件安全与漏洞
x138702859571 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
iCxhust1 小时前
C#进程管理程序
开发语言·汇编·stm32·单片机·c#·微机原理
凡人叶枫2 小时前
Effective C++ 条款28:避免使用 handles 指向对象内部
linux·服务器·开发语言·c++·嵌入式开发
努力成为AK大王2 小时前
并发编程的核心挑战、优化方案与核心知识点总结
java·开发语言·数据库
AI 编程助手GPT2 小时前
用 Python 做一个世界杯赛前分析脚本:以巴西 vs 摩洛哥为例
开发语言·网络·人工智能·python·chatgpt
lihao lihao3 小时前
Linux信号
开发语言·c++·算法
Java患者·3 小时前
《Python 人脸识别入门实践:从人脸检测到人脸比对完整实现》
开发语言·python·opencv·目标检测·计算机视觉·目标跟踪·视觉检测