21-5-02 砖墙

  1. 砖墙 难度[中等]

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

你现在要画一条 自顶向下 的、穿过 最少 砖块的垂线。如果你画的线只是从砖块的边缘经过,就不算穿过这块砖。你不能沿着墙的两个垂直边缘之一画线,这样显然是没有穿过一块砖的。

给你一个二维数组 wall ,该数组包含这堵墙的相关信息。其中,wall[i] 是一个代表从左至右每块砖的宽度的数组。你需要找出怎样画才能使这条线 穿过的砖块数量最少 ,并且返回 穿过的砖块数量 。

示例 1:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GcjDA5eV-1619929167644)(https://s3-us-west-2.amazonaws.com/secure.notion-static.com/0792bb83-9bd6-4635-bb0d-54b9e9104ab9/Untitled.png)]

输入: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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/brick-wall
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


解法:HashMap存储缝隙

public int leastBricks(List<List<Integer>> wall) {
        int n = wall.size();
        Map<Integer,Integer> map =  new HashMap<>();
        for(int i=0,sum=0;i<n;i++,sum=0){
            for(int w:wall.get(i)){
                sum+=w;
                //将缝隙加入map中
                map.put(sum,map.getOrDefault(sum,0)+1);
            }
            //边界是不算缝隙的得移除
            map.remove(sum);
        }
        int max=0;
        //取出最大的缝隙,
        for(int i:map.keySet()){
            if(map.get(i)>max)max=map.get(i);
        }
        //砖的高度减去最大缝隙就是穿过的最少砖数
        return n-max;
    } 

参考


此文章创于本人学习时的记录,如有错误或更优解还请指出

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值