当前位置:   article > 正文

【LeetCode】每日一题——419. 甲板上的战舰_在一个n*m的巨大矩阵状空地中,停放着一些飞机,为了日后移动方便,即使土地资源紧张

在一个n*m的巨大矩阵状空地中,停放着一些飞机,为了日后移动方便,即使土地资源紧张

目录

题目:

方法一:

方法二: 


题目:

给你一个大小为 m x n 的矩阵 board 表示甲板,其中,每个单元格可以是一艘战舰 'X' 或者是一个空位 '.' ,返回在甲板 board 上放置的 战舰 的数量。

战舰 只能水平或者垂直放置在 board 上。换句话说,战舰只能按 1 x k(1 行,k 列)或 k x 1(k 行,1 列)的形状建造,其中 k 可以是任意大小。两艘战舰之间至少有一个水平或垂直的空位分隔 (即没有相邻的战舰)。

意思就是一个x行和列 ,仅仅统计一次

 

方法一:

普通解法,在遍历到一个'X'时,DFS以下与其连接的'X';
修改原数组为其他字符;
统计最后个数。

  1. class Solution:
  2. def countBattleships(self, board):
  3. cnt = 0
  4. for i in range(len(board)):
  5. for j in range(len(board[0])):
  6. if board[i][j] == 'X':
  7. board[i][j] = 'Y'
  8. m,n = i,j
  9. while n + 1 < len(board[0]) and board[m][n + 1] == 'X':
  10. board[m][n + 1] = 'Y'
  11. n += 1
  12. while m + 1 < len(board) and board[m + 1][n] == 'X':
  13. board[m + 1][n] = 'Y'
  14. m += 1
  15. cnt += 1
  16. return cnt

 for i in range(len(board)):
            for j in range(len(board[0])):

遍历整个数组

方法二: 

我们可以通过战舰的头来判断个数,当一个点上面或者左面X说明它战舰中间部分,跳过即可!

  1. class Solution:
  2. def countBattleships(self, board: List[List[str]]) -> int:
  3. row = len(board)
  4. col = len(board[0])
  5. res = 0
  6. for i in range(row):
  7. for j in range(col):
  8. if board[i][j] == ".": continue
  9. if i > 0 and board[i - 1][j] == "X": continue
  10. if j > 0 and board[i][j - 1] == "X": continue
  11. res += 1
  12. return res

1) if board[i][j] == ".": continue 意思是如果board[i][j] == "."

继续 for j in range(col):

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/718341
推荐阅读
相关标签
  

闽ICP备14008679号