CF1534F1.Falling Sand (Easy Version)
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
This is the easy version of the problem. The difference between the versions is the constraints on ai . You can make hacks only if all versions of the problem are solved.
Little Dormi has recently received a puzzle from his friend and needs your help to solve it.
The puzzle consists of an upright board with n rows and m columns of cells, some empty and some filled with blocks of sand, and m non-negative integers a1,a2,…,am ( 0≤ai≤n ). In this version of the problem, ai will be equal to the number of blocks of sand in column i .
When a cell filled with a block of sand is disturbed, the block of sand will fall from its cell to the sand counter at the bottom of the column (each column has a sand counter). While a block of sand is falling, other blocks of sand that are adjacent at any point to the falling block of sand will also be disturbed and start to fall. Specifically, a block of sand disturbed at a cell (i,j) will pass through all cells below and including the cell (i,j) within the column, disturbing all adjacent cells along the way. Here, the cells adjacent to a cell (i,j) are defined as (i−1,j) , (i,j−1) , (i+1,j) , and (i,j+1) (if they are within the grid). Note that the newly falling blocks can disturb other blocks.
In one operation you are able to disturb any piece of sand. The puzzle is solved when there are at least ai blocks of sand counted in the i -th sand counter for each column from 1 to m .
You are now tasked with finding the minimum amount of operations in order to solve the puzzle. Note that Little Dormi will never give you a puzzle that is impossible to solve.
输入格式
The first line consists of two space-separated positive integers n and m ( 1≤n⋅m≤400000 ).
Each of the next n lines contains m characters, describing each row of the board. If a character on a line is '.', the corresponding cell is empty. If it is '#', the cell contains a block of sand.
The final line contains m non-negative integers a1,a2,…,am ( 0≤ai≤n ) — the minimum amount of blocks of sand that needs to fall below the board in each column. In this version of the problem, ai will be equal to the number of blocks of sand in column i .
输出格式
Print one non-negative integer, the minimum amount of operations needed to solve the puzzle.
输入输出样例
输入#1
5 7 #....#. .#.#... #....#. #....## #.#.... 4 1 1 1 0 3 1
输出#1
3
输入#2
3 3 #.# #.. ##. 3 1 1
输出#2
1
说明/提示
For example 1 , by disturbing both blocks of sand on the first row from the top at the first and sixth columns from the left, and the block of sand on the second row from the top and the fourth column from the left, it is possible to have all the required amounts of sand fall in each column. It can be proved that this is not possible with fewer than 3 operations, and as such the answer is 3 . Here is the puzzle from the first example.
For example 2 , by disturbing the cell on the top row and rightmost column, one can cause all of the blocks of sand in the board to fall into the counters at the bottom. Thus, the answer is 1 . Here is the puzzle from the second example.