砖墙(力扣)Map + 思维 JAVA

你的面前有一堵矩形的、由 n 行砖块组成的砖墙。这些砖块高度相同(也就是一个单位高)但是宽度不同。每一行砖块的宽度之和相等。

你现在要画一条 自顶向下 的、穿过 最少

砖块的垂线。如果你画的线只是从砖块的边缘经过,就不算穿过这块砖。你不能沿着墙的两个垂直边缘之一画线,这样显然是没有穿过一块砖的。

给你一个二维数组 wall ,该数组包含这堵墙的相关信息。其中,wall[i]

是一个代表从左至右每块砖的宽度的数组。你需要找出怎样画才能使这条线 穿过的砖块数量最少 ,并且返回 穿过的砖块数量 。

输入:wall =

\[1,2,2,1\], \[3,1,2\], \[1,3,2\], \[2,4\], \[3,1,2\], \[1,3,1,1

]

输出:2

示例 2:

输入:wall =

\[1\], \[1\], \[1

]

输出:3

提示:

n == wall.length

1 <= n <= 10^4

1 <= wall[i].length <= 10^4

1 <= sum(wall[i].length) <= 2 * 10^4

对于每一行 i ,sum(wall[i]) 是相同的

1 <= wall[i][j] <= 2^31 - 1

解题思路:

1、正着不好求,但逆向思维:求穿过砖块边缘数的最大值有奇效

2、需要神器HashMap来更新:<砖块边缘,数量>

3、最右边砖块边缘是不符合要求的,所以不记录

4、最后用总述职砖块数 - 最大边缘数即可

代码:

java 复制代码
class Solution {
    public int leastBricks(List<List<Integer>> wall) {
    	   Map<Integer, Integer> map = new HashMap<Integer, Integer>();
           for(List<Integer> s : wall) {
        	  int len = s.size();
        	  int sum = 0;
        	  for(int i = 0; i < len - 1; i ++) {
        		  sum = sum + s.get(i);
        		  map.put(sum, map.getOrDefault(sum, 0) + 1);
        	  }
           }
           int maxres = 0;
           for(Map.Entry<Integer, Integer> a : map.entrySet()) {
        	   maxres = Math.max(maxres, a.getValue());
           }
           return wall.size() - maxres;
    }
}
相关推荐
逝水如流年轻往返染尘8 分钟前
JAVA中的抽象类
java·开发语言
旖-旎10 分钟前
二分查找(1)
c++·算法·二分查找·力扣·双指针
困死,根本不会14 分钟前
【C 语言】指针学习笔记:从底层原理到实战应用
c语言·开发语言·笔记·学习·算法
小范自学编程21 分钟前
算法训练营 Day38 - 动态规划part07
算法·动态规划
hx8622733 分钟前
Java MySQL 连接
java·mysql·adb
lpfasd12335 分钟前
Kubernetes (K8s) 底层早已不再直接使用 Docker 引擎了
java·docker·kubernetes
aq553560038 分钟前
SpringBoot有几种获取Request对象的方法
java·spring boot·后端
星空露珠1 小时前
迷你世界UGC3.0脚本Wiki全局函数
开发语言·数据库·算法·游戏·lua
小王不爱笑1321 小时前
排序算法 Java
数据结构·算法·排序算法
无敌憨憨大王1 小时前
二叉树的最短路径长度(BFS+DFS)
算法·深度优先·宽度优先