LeetCode1706
LeetCode1706
目录
- LeetCode1706
- 题目描述
- 示例
- 题目理解
- 问题描述
- 示例分析
- 思路分析
- 问题核心
- 代码段
- 代码逐行讲解
- 1. 获取网格的列数
- 2. 初始化结果数组
- 3. 遍历每个球
- 4. 逐行模拟下落过程
- 5. 检查是否卡住
- 6. 记录结果
- 7. 返回结果数组
- 复杂度分析
- 时间复杂度
- 空间复杂度
- 总结的知识点
- 1. 二维数组的遍历
- 2. 边界检查
- 3. 条件判断
- 4. 模拟过程
- 5. 结果记录
- 整合
- 总结
题目描述
用一个大小为 m x n 的二维网格 grid 表示一个箱子。你有 n 颗球。箱子的顶部和底部都是开着的。
箱子中的每个单元格都有一个对角线挡板,跨过单元格的两个角,可以将球导向左侧或者右侧。
- 将球导向右侧的挡板跨过左上角和右下角,在网格中用 1 表示。
- 将球导向左侧的挡板跨过右上角和左下角,在网格中用 -1 表示。
在箱子每一列的顶端各放一颗球。每颗球都可能卡在箱子里或从底部掉出来。如果球恰好卡在两块挡板之间的 “V” 形图案,或者被一块挡导向到箱子的任意一侧边上,就会卡住。
返回一个大小为 n 的数组 answer ,其中 answer[i] 是球放在顶部的第 i 列后从底部掉出来的那一列对应的下标,如果球卡在盒子里,则返回 -1 。
示例
示例 1:
输入: grid = [[1,1,1,-1,-1],[1,1,1,-1,-1],[-1,-1,-1,1,1],[1,1,1,1,-1],[-1,-1,-1,-1,-1]]
输出: [1,-1,-1,-1,-1]
解释:
- 球0从第0列开始下落,最终落在第1列。
- 球1从第1列开始下落,卡在第1列和第2列之间。
- 球2从第2列开始下落,卡在第2列和第3列之间。
- 球3从第3列开始下落,卡在第3列和第4列之间。
- 球4从第4列开始下落,卡在第4列。
示例 2:
输入: grid = [[-1]]
输出: [-1]
解释:
- 球0从第0列开始下落,卡在第0列。
好的,我们将对 力扣 1706 题(球会落何处) 进行全面细致的分析,包括题目理解、解题思路、代码实现、复杂度分析以及涉及的知识点总结。通过这种方式,我们可以更深入地理解这道题目的核心逻辑和实现细节。
题目理解
问题描述
我们有一个大小为 m x n
的二维网格 grid
,其中每个单元格的值可以是 1
或 -1
:
1
表示单元格的右上方和左下方有对角线,球会向右移动。-1
表示单元格的左上方和右下方有对角线,球会向左移动。
球从网格的顶部开始下落,每个球会从第一行的某个列开始下落。球在移动过程中会遵循以下规则:
- 如果球碰到
1
,它会向右移动。 - 如果球碰到
-1
,它会向左移动。 - 如果球移动时碰到边界或者移动方向与相邻单元格的对角线方向不一致,球会卡住。
我们需要返回一个大小为 n
的数组,表示每个球最终会落在哪个列。如果球卡住了,则对应位置为 -1
。
示例分析
输入:
grid = [[1, 1, 1, -1, -1],[1, 1, 1, -1, -1],[-1, -1, -1, 1, 1],[1, 1, 1, 1, -1],[-1, -1, -1, -1, -1]
]
输出:
[1, -1, -1, -1, -1]
解释:
- 球 0 从第 0 列开始下落,最终落在第 1 列。
- 球 1 从第 1 列开始下落,卡在第 1 列和第 2 列之间。
- 球 2 从第 2 列开始下落,卡在第 2 列和第 3 列之间。
- 球 3 从第 3 列开始下落,卡在第 3 列和第 4 列之间。
- 球 4 从第 4 列开始下落,卡在第 4 列。
思路分析
问题核心
我们需要模拟每个球在网格中的下落过程,并确定它们最终会落在哪个列。网格中的每个单元格的值可以是 1
或 -1
:
1
表示单元格的右上方和左下方有对角线,球会向右移动。-1
表示单元格的左上方和右下方有对角线,球会向左移动。
球的下落过程需要遵循以下规则:
- 如果球碰到
1
,它会向右移动。 - 如果球碰到
-1
,它会向左移动。 - 如果球移动时碰到边界或者移动方向与相邻单元格的对角线方向不一致,球会卡住。
思路拆解后的重点: 模拟每个球的下落和移动方向的计算
代码段
class Solution {public int[] findBall(int[][] grid) {int len = grid[0].length;int[] ans = new int[len];for (int i = 0; i < len; i++) {int k = i;for (int[] row : grid) {int d = row[k];k += d;if (k < 0 || k == len || row[k] != d) {k = -1;break;}}ans[i] = k;}return ans;}
}
代码逐行讲解
下面有整合
1. 获取网格的列数
int len = grid[0].length;
grid
是一个二维数组,表示网格。grid[0].length
获取网格的列数len
。
2. 初始化结果数组
int[] ans = new int[len];
ans
是一个大小为len
的数组,用于存储每个球的最终位置。
3. 遍历每个球
for (int i = 0; i < len; i++) {int k = i; // 当前球的起始列
- 使用
for
循环遍历每个球,i
表示球的起始列。 k
是当前球的列位置,初始化为起始列i
。
4. 逐行模拟下落过程
for (int[] row : grid) {int d = row[k]; // 当前单元格的值(1 或 -1)k += d; // 计算下一列
- 使用增强的
for
循环遍历每一行row
。 d
是当前单元格的值,可以是1
或-1
。k += d
计算球的下一列位置:- 如果
d = 1
,球向右移动,k
增加 1。 - 如果
d = -1
,球向左移动,k
减少 1。
- 如果
5. 检查是否卡住
if (k < 0 || k == len || row[k] != d) {k = -1; // 球卡住break;
}
- 边界检查:
- 如果
k < 0
,球移动到左边界外。 - 如果
k == len
,球移动到右边界外。
- 如果
- 方向一致性检查:
- 如果
row[k] != d
,球的移动方向与相邻单元格的对角线方向不一致。
- 如果
- 如果球卡住,将
k
设置为-1
,并跳出循环。
6. 记录结果
ans[i] = k; // 记录结果
- 将每个球的最终位置
k
记录到结果数组ans
中。
7. 返回结果数组
return ans; // 返回结果数组
- 返回结果数组
ans
,其中每个元素表示对应球的最终位置。
复杂度分析
时间复杂度
- 对于每个球,我们需要逐行模拟下落过程,最多需要遍历
m
行。 - 总共有
n
个球,因此总时间复杂度为 O(m * n)。
空间复杂度
- 我们只需要一个大小为
n
的数组来存储结果,因此空间复杂度为 O(n)。
总结的知识点
1. 二维数组的遍历
- 使用增强的
for
循环遍历二维数组grid
。 - 外层循环遍历列,内层循环遍历行。
2. 边界检查
- 使用条件判断检查球是否移动到网格的边界外。
3. 条件判断
- 使用
if
语句判断球是否卡住。
4. 模拟过程
- 通过逐行模拟球的下落过程,实时更新球的位置。
5. 结果记录
- 使用数组
ans
记录每个球的最终位置。
整合
class Solution {public int[] findBall(int[][] grid) {int len = grid[0].length; // 获取网格的列数int[] ans = new int[len]; // 初始化结果数组// 遍历每个球for (int i = 0; i < len; i++) {int k = i; // 当前球的起始列// 逐行模拟下落过程for (int[] row : grid) {int d = row[k]; // 当前单元格的值(1 或 -1)k += d; // 计算下一列// 检查是否卡住if (k < 0 || k == len || row[k] != d) {k = -1; // 球卡住break;}}ans[i] = k; // 记录结果}return ans; // 返回结果数组}
}
总结
我认为整体上还是简洁高效,逐行模拟球的下落过程,并实时检查是否卡住,来进行判断并解决问题。
相关文章:

LeetCode1706
LeetCode1706 目录 LeetCode1706题目描述示例题目理解问题描述 示例分析思路分析问题核心 代码段代码逐行讲解1. 获取网格的列数2. 初始化结果数组3. 遍历每个球4. 逐行模拟下落过程5. 检查是否卡住6. 记录结果7. 返回结果数组 复杂度分析时间复杂度空间复杂度 总结的知识点1. …...
2517. 礼盒的最大甜蜜度(Maximum Tastiness of Candy Box)
2517. 礼盒的最大甜蜜度(Maximum Tastiness of Candy Box) 问题描述 给定一个正整数数组 price,其中 price[i] 表示第 i 类糖果的价格,另给定一个正整数 k。商店将 k 类不同糖果组合成礼盒出售。礼盒的甜蜜度是礼盒中任意两种糖…...

Golang 的字符编码与 regexp
前言 最近在使用 Golang 的 regexp 对网络流量做正则匹配时,发现有些情况无法正确进行匹配,找到资料发现 regexp 内部以 UTF-8 编码的方式来处理正则表达式,而网络流量是字节序列,由其中的非 UTF-8 字符造成的问题。 我们这里从 G…...

利用ollama 与deepseek r1大模型搭建本地知识库
1.安装运行ollama ollama下载 https://ollama.com/download/windows 验证ollama是否安装成功 ollama --version 访问ollama本地地址: http://localhost:11434/ 出现如下界面 ollama运行模型 ollama run llama3.2 ollama常用操作命令 启动 Ollama 服务…...

Java短信验证功能简单使用
注册登录阿里云官网:https://www.aliyun.com/ 搜索短信服务 自己一步步申请就可以了 开发文档: https://next.api.aliyun.com/api-tools/sdk/Dysmsapi?version2017-05-25&languagejava-tea&tabprimer-doc 1.引入依赖 <dependency>…...

CAS单点登录(第7版)21.可接受的使用政策
如有疑问,请看视频:CAS单点登录(第7版) 可接受的使用政策 概述 可接受的使用政策 CAS 也称为使用条款或 EULA,它允许用户在继续应用程序之前接受使用策略。此功能的生产级部署需要修改流,以便通过外部存…...

53倍性能提升!TiDB 全局索引如何优化分区表查询?
作者: Defined2014 原文来源: https://tidb.net/blog/7077577f 什么是 TiDB 全局索引 在 TiDB 中,全局索引是一种定义在分区表上的索引类型,它允许索引分区与表分区之间建立一对多的映射关系,即一个索引分区可以对…...

Pythong 解决Pycharm 运行太慢
Pythong 解决Pycharm 运行太慢 官方给Pycharm自身占用的最大内存设低估了限制,我的Pycharm刚开始默认是256mb。 首先找到自己的Pycharm安装目录 根据合适自己的改 保存,重启Pycharm...

库里存储的数据有大量回车时,该如何进行存取
如图,打印模板存了很多坐标性的字段数据: 大量带换行的文本数据存到库里之后取出,前端需要做非空、合法校验, 然后在循环中,使用eval 函数接收每一句字符串,去执行这句 JavaScript 代码。 let arrStr tem…...

【devops】Github Actions Secrets | 如何在Github中设置CI的Secret供CI的yaml使用
一、Github Actions 1、ci.yml name: CIon: [ push ]jobs:build:runs-on: ubuntu-lateststeps:- name: Checkout codeuses: actions/checkoutv3- name: Set up Gouses: actions/setup-gov4with:go-version: 1.23.0- name: Cache Go modulesuses: actions/cachev3with:path: |…...

体验 DeepSeek-R1:解密 1.5B、7B、8B 版本的强大性能与应用
文章目录 🍋引言🍋DeepSeek 模型简介🍋版本更新:1.5B、7B、8B 的区别与特点🍋模型评估🍋体验 DeepSeek 的过程🍋总结 🍋引言 随着大规模语言模型的持续发展,许多模型在性…...
一文说清楚什么是Token以及项目中使用Token延伸的问题
首先可以参考我的往期文章,我这里说清楚了Cookie,Seesion,Token以及JWT是什么 其实Token你就可以理解成这是一个认证令牌就好了 详细分清Session,Cookie和Token之间的区别,以及JWT是什么东西_还分不清 cookie、sessi…...
大模型-Tool call、检索增强
大模型 Tool call 心知天气:https://www.seniverse.com/ 例子:调用天气接口 API from openai import OpenAI import requests import json """ ##### 天气接口 API 密钥获取:https://www.free-api.com/doc/558 ##### &quo…...
【算法】【区间和】acwing算法基础 802. 区间和 【有点复杂,但思路简单】
题目 假定有一个无限长的数轴,数轴上每个坐标上的数都是 0。 现在,我们首先进行 n 次操作,每次操作将某一位置 x 上的数加 c。 接下来,进行 m 次询问,每个询问包含两个整数 l 和 r,你需要求出在区间 [l,r] …...

Ubuntu22.04通过Docker部署Jeecgboot
程序发布环境包括docker、mysql、redis、maven、nodejs、npm等。 一、安装docker 1、用如下命令卸载旧Docker: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done 2、安装APT环境依赖包…...

HTML4
HTML 初体验 1.鼠标右键 > 新建 > 文本文档 > 输入以下内容,并保存 2.修改后缀为 .html ,然后双击打开即可 这里的后缀名,使用 .htm 也可以,但推荐使用更标准的 .html <marquee>尚硅谷,让天下没有难…...

STM32F10X 启动文件完整分析
最近在准备面试相关 顺便复盘总结一下之前的内容 启动文件在基于ARM的芯片是很重要的组成部分,它主要负责完成芯片上电启动时的一系列初始化工作和各种异常及中断的入口地址。 也是理解bootloader自举的关键点,所以需要理解一下 1. 向量表定义 启动文件…...
typescript快速入门之安装与运行
安装 安装ts环境,最好全局安装,这样就不需要开一个项目又安装 npm i -g typescript初始化 可以运行初始化配置文件,也可以手动生成;不生成的话会运行默认配置 使用默认配置 把ts文件转成js文件使用的是es3语言,语…...
React源码解读
配置React源码本地调试环境 本次环境构建采用了node版本为16、react-scripts 版本号为 3.4.4,源码下载地址 react源码调试: react源码调试环境 使用 create-react-app 脚手架创建项目 npx create-react-app react-test 进入刚刚下载的目录,弹射 crea…...

【DeepSeek-R1】 API申请(火山方舟联网版)
DeepSeek-R1 API申请(火山方舟联网版) 1、新建联网版应用2、开通信息增强服务3、开启联网内容插件4、创建接入点5、获取模型名称6、获取API Key 如果第一次注册账号,请先按照文章《【Deepseek-R1】 API申请(火山方舟)》…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?
编辑:陈萍萍的公主一点人工一点智能 未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战,在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...

ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...

srs linux
下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935,SRS管理页面端口是8080,可…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...
【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具
第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...

GraphRAG优化新思路-开源的ROGRAG框架
目前的如微软开源的GraphRAG的工作流程都较为复杂,难以孤立地评估各个组件的贡献,传统的检索方法在处理复杂推理任务时可能不够有效,特别是在需要理解实体间关系或多跳知识的情况下。先说结论,看完后感觉这个框架性能上不会比Grap…...
JavaScript 标签加载
目录 JavaScript 标签加载script 标签的 async 和 defer 属性,分别代表什么,有什么区别1. 普通 script 标签2. async 属性3. defer 属性4. type"module"5. 各种加载方式的对比6. 使用建议 JavaScript 标签加载 script 标签的 async 和 defer …...