【LeetCode】每日一题——419. 甲板上的战舰

目录

题目:

方法一:

方法二: 


题目:

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

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

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

方法一:

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

class Solution:
    def countBattleships(self, board):
        cnt = 0
        for i in range(len(board)):
            for j in range(len(board[0])):
                if board[i][j] == 'X':
                    board[i][j] = 'Y'
                    m,n = i,j
                    while n + 1 < len(board[0]) and board[m][n + 1] == 'X':
                        board[m][n + 1] = 'Y'
                        n += 1
                    while m + 1 < len(board) and board[m + 1][n] == 'X':
                        board[m + 1][n] = 'Y'
                        m += 1
                    cnt += 1
        return cnt

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

遍历整个数组

方法二: 

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

class Solution:
    def countBattleships(self, board: List[List[str]]) -> int:
        row = len(board)
        col = len(board[0])
        res =  0
        for i in range(row):
            for j in range(col):
                if board[i][j] == ".": continue
                if i > 0 and board[i - 1][j] == "X": continue
                if j > 0 and board[i][j - 1] == "X": continue
                res += 1
        return res

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

继续 for j in range(col):

 

猜你喜欢

转载自blog.csdn.net/qq_62932195/article/details/122008547
今日推荐