接雨水问题 + 输入优化

大雨过后,一些高低不平的地方就会形成积水,俗称为"坑"。这里我们将问题简化为只考虑一段路面的横截面。我们将这一段截面上的土地分割成单位宽度的窄条,测量出每个窄条的高度。假设有无穷多的水量从天而降,请你计算一下,这段路面上会形成多少个水坑?坑的最大深度是多少毫米?

顺便祝大家新年少踩坑!

输入格式:

输入第一行给出一个正整数 N(≤105)。随后一行给出 N 个非负整数,为路面横截面总左到右的单位宽度窄条的高度,以毫米为单位,不超过 1000。

输出格式:

输出分两行,第一行输出水坑的个数,第二行输出所有水坑中最大的深度,以毫米为单位。

注意:即使两个相邻的水坑有相同高度的水平面,只要之间有窄条相隔,就算是两个水坑。

输入样例:

12

1 4 2 10 7 1 2 1 8 3 1 2

输出样例:

3

7

样例说明:

下图给出了样例中得到的水坑示意图。

import java.io.*;

import java.util.ArrayList;

import java.util.List;

import java.util.Scanner;

import java.util.StringTokenizer;

public class Main {

public static void main(String\[\] args) throws IOException {

InputStream in = System.in;

int n = readInt(in);

int\[\] arr = new intn;

for (int i = 0; i < n; i++) {

arri = readInt(in);

}

int\[\] leftmax = new intn;

leftmax0 = arr0;

for (int i = 1; i <n ; i++) {

leftmaxi = Math.max(leftmaxi - 1 , arri);

}

int\[\] rigmax = new intn;

rigmaxn - 1 = arrn - 1;

for (int i = n - 2; i >= 0 ; i--) {

rigmaxi = Math.max(rigmaxi + 1 , arri);

}

int dep = 0;

int con = 0;

for (int i = 1; i < n - 1 ; i++) {

int tmp = Math.min(leftmaxi , rigmaxi) - arri;

dep = Math.max(dep , tmp);

if(Math.min(leftmaxi - 1 , rigmaxi - 1) - arri - 1 == 0 && Math.min(leftmaxi , rigmaxi) - arri != 0)

con++;

}

System.out.println(con);

System.out.println(dep);

}

static int readInt(InputStream in) throws IOException{

int c = 0;

int x = 0;

while((c = in.read()) < '0')

;

do {

x = x * 10 + c - '0';

}

while ((c = in.read()) >= '0');

return x;

}

}

readIntBufferedReader 快的本质是:它砍掉了所有 "无用的封装",只做 "读数字" 这一件事,而 BufferedReader 是通用型工具,自带大量冗余逻辑

为什么快?

少了「字符串解析」的额外开销

BufferedReader 读取数字的常规写法是:

java

运行

复制代码
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String line = br.readLine(); // 先读成字符串
int num = Integer.parseInt(line); // 再转成整数
  • 第一步:把字节流 → 字符串(要处理编码、拼接字符);
  • 第二步:把字符串 → 整数(要校验格式、逐字符转数字)。

而你的 readInt 是:

java

运行

复制代码
// 直接从字节流 → 整数,跳过"字符串"中间层
do {
    x = x * 10 + c - '0'; // 字节直接转数字,一步到位
} while ((c = in.read()) >= '0');

✅ 少了「字符串创建 + 解析」,这是最大的提速点

相关推荐
折哥的程序人生 · 物流技术专研12 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
xxie12379412 小时前
return与print
开发语言·python
秋912 小时前
从 Python 后端工程师转型 AI Engineer(AI 工程化)的完整补课清单(2026实战版)
开发语言·人工智能·python
一条泥憨鱼12 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
云烟成雨TD13 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
程序员二叉13 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
周航宇JoeZhou13 小时前
JB3-9-SpringAI(二)
java·ai·agent·多智能体·调度·智能体·观察
好家伙VCC13 小时前
Web Components主题热切换方案揭秘
java·前端
慕木沐13 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
想吃火锅100513 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展