当前位置: 首页 > news >正文

LeetCode:419. 甲板上的战舰(遍历 Java)

目录

419. 甲板上的战舰

题目描述:

实现代码与解析:

遍历

原理思路:


419. 甲板上的战舰

题目描述:

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

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

示例 1:

输入:board = [["X",".",".","X"],[".",".",".","X"],[".",".",".","X"]]
输出:2

示例 2:

输入:board = [["."]]
输出:0

提示:

  • m == board.length
  • n == board[i].length
  • 1 <= m, n <= 200
  • board[i][j] 是 '.' 或 'X'

实现代码与解析:

遍历

class Solution {public int countBattleships(char[][] board) {int n = board.length;int m = board[0].length;int res = 0;for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {if (board[i][j] == 'X' && (i == 0 || board[i - 1][j] != 'X') && (j == 0 || board[i][ j -1] != 'X')) {res ++;}}}return res;}
}

原理思路:

        只统计船的左上点位。因为船形状是固定的只能一条线。

        如果不是那么也很简单,就是图论,dfs或dfs标记一下以及遍历过的点即可。可以看下面这题的解析。

LeetCode:200. 岛屿数量(BFS Java)-CSDN博客

http://www.lryc.cn/news/369855.html

相关文章:

  • 【python】OpenCV—Blob Detection(11)
  • 【C++】 基础复习 | 数据类型,输入,输出流 scanf printf
  • linux pxe和无人值守
  • Questflow借助MongoDB Atlas以AI重新定义未来工作方式
  • 数值计算精度问题(浮点型和双整型累加精度测试)
  • 算法训练营day56
  • 基于STM32的智能水产养殖系统(二)
  • [工具探索]富士mini90拍立得使用指南
  • VMware导入小白分享的MacOS版本之后,无法开机的解决方案
  • 【CSAPP导读】导论
  • “新E代弯道王”MAZDA EZ-6亮相2024重庆国际车展
  • 【lesson11】客户端backUp类的实现
  • 数据结构--关键路径
  • SSTI注入漏洞
  • Day11 - Day15
  • 启航信息学奥林匹克:青少年NOI学习路线与策略指南
  • 易舟云财务软件:数字化时代的财务管家
  • catia零件装配中通过指南针移动零件
  • 如何使用免费的 Instant Data Scraper快速抓取网页数据
  • 【仿真建模-anylogic】事件之手动定时触发
  • ElasticSearch学习笔记之三:Logstash数据分析
  • 求职力扣刷题DAY20--二叉树 part06
  • Error:Kotlin: Module was compiled with an incompatible version of Kotlin.
  • 关于flutter 启动 页面加载空白(三四秒空白页面)
  • 计量校准证书和检定证书区别,企业仪器校准要哪种证书好?
  • 解析Java中1000个常用类:StackWalker类,你学会了吗?
  • 【代码随想录算法训练Day32】LeetCode 122 买卖股票的最佳时机 II、LeetCode 55.跳跃游戏、LeetCode 45.跳跃游戏II
  • Qt之QGraphicsView —— 笔记3:矩形图元连接(附完整源码)
  • 2024年,计算机相关专业还值得选择吗?
  • 流批一体计算引擎-10-[Flink]中的常用算子和DataStream转换