1861。旋转盒子
难度:中等
主题:数组、两个指针、矩阵
给你一个 m x n 的字符框矩阵,代表盒子的侧视图。盒子的每个单元格都是以下之一:
- 一块石头“#”
- 静止障碍物“*”
- 空“.”
盒子顺时针旋转90度,导致一些石头因重力而掉落。每块石头都会落下,直到落在障碍物、另一块石头或盒子的底部。重力不会影响障碍物的位置,盒子旋转产生的惯性不会影响石头的水平位置。
保证盒子中的每块石头都放置在障碍物、另一块石头或盒子的底部上。
返回一个 n x m 矩阵,表示上述旋转后的盒子。
示例1:
- 输入: box = [["#",".","#"]]
- 输出: [["."], ["#"], ["#"]]
示例2:
- 输入: box = [["#",".","","."], ["#","#","","."] ]
- 输出: [["#","."], ["#","#"], ["",""], [".","。 “]]
示例 3:
- 输入: box = [["#","#","",".","","."], ["#","#", "#","*",".","."], ["#","#","#",".","#","."]]
- 输出: [[".","#","#"], [".","#","#"], ["#","#"," "], ["#","","."], ["#",".","*"], ["#",".","."]]
约束:
- m == box.length
- n == box[i].length
- 1
- box[i][j] 是“#”、“*”或“.”。
提示:
- 使用关系rotatedBox[i][j] = box[m - 1 - j][i]. 旋转盒子
- 从盒子底部开始迭代,对于每个空单元格检查其上方是否有任何石头且它们之间没有障碍物。
解决方案:
我们需要遵循几个不同的步骤:
旋转盒子:我们首先将矩阵顺时针旋转90度。旋转后的矩阵将有 n 行和 m 列,其中 n 是原始框中的列数,m 是行数。
重力效果:旋转后,我们需要模拟重力的效果。这意味着所有石头 ('#') 都应该“落到”新列的底部,只有在遇到障碍物 ('*') 或另一块石头 ('#') 时才停止。
方法:
旋转:旋转后,原矩阵中第[i][j]位置的元素将被放置到旋转后的第[j][m-1-i]位置矩阵。
重力模拟:我们需要从下到上处理每一列。如果有一块石头('#'),它就会掉下来,直到到达障碍物或底部。如果单元格为空(“.”),则可以容纳一块石头。
分步说明:
- 为旋转框创建一个新矩阵。
- 迭代旋转矩阵的每一列(旋转后).
- 通过从底部开始向上移动来模拟每列的重力。将石头 ('#') 尽可能向下放置,将障碍物 ('*') 留在原处。
- 返回最终旋转矩阵.
让我们用 PHP 实现这个解决方案:1861。旋转盒子
<?php function rotateTheBox($box) { ... ... ... /** * go to ./solution.php */ } // Example Usage $box = [ ["#", ".", "#"], ]; print_r(rotateTheBox($box)); $box = [ ["#", ".", "*", "."], ["#", "#", "*", "."], ]; print_r(rotateTheBox($box)); $box = [ ["#", "#", "*", ".", "*", "."], ["#", "#", "#", "*", ".", "."], ["#", "#", "#", ".", "#", "."], ]; print_r(rotateTheBox($box)); ?>
解释:
-
模拟重力:
- 从右到左遍历每一行。使用指针(emptySlot)来跟踪下一块石头应该落下的位置。
- 如果遇到石头(#),将其移动到emptySlot,然后递减emptySlot。
- 如果遇到障碍物(*),将emptySlot重置到障碍物之前的位置。
-
旋转矩阵:
- 创建一个新矩阵,其中旋转框中 [i][j] 处的元素取自原始框的 [m - 1 - j][i]。
示例输出
输入:
$box = [ ["#", ".", "#"], ];
输出:
[ [".",], ["#",], ["#",], ]
输入:
$box = [ ["#", ".", "*", "."], ["#", "#", "*", "."], ];
输出:
[ ["#", "."], ["#", "#"], ["*", "*"], [".", "."], ]
时间复杂度
- 重力模拟:O(m x n),当我们迭代矩阵中的每个元素时。
- 旋转:O(m x n),当我们创建旋转矩阵时。
总计:O(m x n)。
空间复杂度
- O(m x n) 旋转矩阵。
这个解决方案是高效的并且遵守问题的约束。
联系链接
如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!
如果您想要更多类似的有用内容,请随时关注我:
- 领英
- GitHub
以上是旋转盒子的详细内容。更多信息请关注PHP中文网其他相关文章!

PHP用于构建动态网站,其核心功能包括:1.生成动态内容,通过与数据库对接实时生成网页;2.处理用户交互和表单提交,验证输入并响应操作;3.管理会话和用户认证,提供个性化体验;4.优化性能和遵循最佳实践,提升网站效率和安全性。

PHP在数据库操作和服务器端逻辑处理中使用MySQLi和PDO扩展进行数据库交互,并通过会话管理等功能处理服务器端逻辑。1)使用MySQLi或PDO连接数据库,执行SQL查询。2)通过会话管理等功能处理HTTP请求和用户状态。3)使用事务确保数据库操作的原子性。4)防止SQL注入,使用异常处理和关闭连接来调试。5)通过索引和缓存优化性能,编写可读性高的代码并进行错误处理。

在PHP中使用预处理语句和PDO可以有效防范SQL注入攻击。1)使用PDO连接数据库并设置错误模式。2)通过prepare方法创建预处理语句,使用占位符和execute方法传递数据。3)处理查询结果并确保代码的安全性和性能。

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

PHP在电子商务、内容管理系统和API开发中广泛应用。1)电子商务:用于购物车功能和支付处理。2)内容管理系统:用于动态内容生成和用户管理。3)API开发:用于RESTfulAPI开发和API安全性。通过性能优化和最佳实践,PHP应用的效率和可维护性得以提升。

PHP可以轻松创建互动网页内容。1)通过嵌入HTML动态生成内容,根据用户输入或数据库数据实时展示。2)处理表单提交并生成动态输出,确保使用htmlspecialchars防XSS。3)结合MySQL创建用户注册系统,使用password_hash和预处理语句增强安全性。掌握这些技巧将提升Web开发效率。

PHP和Python各有优势,选择依据项目需求。1.PHP适合web开发,尤其快速开发和维护网站。2.Python适用于数据科学、机器学习和人工智能,语法简洁,适合初学者。

PHP仍然具有活力,其在现代编程领域中依然占据重要地位。1)PHP的简单易学和强大社区支持使其在Web开发中广泛应用;2)其灵活性和稳定性使其在处理Web表单、数据库操作和文件处理等方面表现出色;3)PHP不断进化和优化,适用于初学者和经验丰富的开发者。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Atom编辑器mac版下载
最流行的的开源编辑器

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。