博客
关于我
leecode 554 砖墙
阅读量:346 次
发布时间:2019-03-04

本文共 1030 字,大约阅读时间需要 3 分钟。

题目描述
你的面前有一堵矩形的、由 n 行砖块组成的砖墙。这些砖块高度相同(也就是一个单位高)但是宽度不同。每一行砖块的宽度之和应该相等。你现在要画一条 自顶向下 的、穿过 最少 砖块的垂线。如果你画的线只是从砖块的边缘经过,就不算穿过这块砖。你不能沿着墙的两个垂直边缘之一画线,这样显然是没有穿过一块砖的。

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

示例 1:
输入: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

链接:https://leetcode-cn.com/problems/brick-wall

这题目描述真长,唬到了看题人。
题目的大体意思是,穿过的砖缝最多,也就数横穿过的砖块的数量最少。再转换一下思路,是不是要穿过的砖缝对应的横坐标是相同的,因此可以统计每一行砖块所在的横坐标,使用hash来存储对应的横坐标出现的次数,并在这里面找到出现次数最大的一个,该值表示的是砖缝最多的个数,用墙的高度减去最多的砖缝便是最少的穿过的砖块数量。

class Solution {   public:    int leastBricks(vector<vector<int>>& wall) {           unordered_map<int,int> cnt;                for(auto line:wall)        {               int s=0;            for(int i=0;i<line.size()-1;i++)            {                   s+=line[i];                cnt[s]++;            }        }        int res=0;        for(auto& v : cnt)        {               res=max(res,v.second);        }        return wall.size()-res;    }};

转载地址:http://qpse.baihongyu.com/

你可能感兴趣的文章
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>
Mysql 知识回顾总结-索引
查看>>