【LeetCode】【算法】240. 搜索二维矩阵II

server/2024/11/15 8:30:16/

LeetCode 240. 搜索二维矩阵II

题目描述

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。

思路

思路:K神真强啊240.搜索二维矩阵II(贪心,清晰图解)

  1. K神的思路实际上就是将矩阵转45°,将矩阵最下边的值作为flag,不断判断flag与target的关系,不断贪心地进行移动,直到找到target值或者flag移动到target为止。因为数组严格满足从左到右升序、从上到下升序的性质,我自己写时候的想法就是通过一堆if-else语句来挪动指针,非常低效,而且超时了(我没有在本地验证自己的代码,不清楚正确性)
  2. 逆时针旋转45度之后,满足这样一种情况:
    假如flag>target,则target一定在flag所在行的上方,即flag在原矩阵中的 “行”可以被消除(j++)
    假如flag<target,则target一定在flag所在列的右方,即flag在原矩阵中的“列”可以被消除(i–)
    通过这样的形式对flag进行一个缩放

代码

class Solution {public boolean searchMatrix(int[][] matrix, int target) {int i = matrix.length - 1, j = 0;while (i >= 0 && j < matrix[0].length) {if (matrix[i][j] > target) i--;else if (matrix[i][j] < target) j++;else return true; // ==的情况}return false;}
}

自己写的垃圾。。。

public boolean searchMatrix2(int[][] matrix, int target) {int i = 0, j = 0;while (i < matrix.length && j < matrix[0].length) {if (matrix[i][j] == target) return true;if (matrix[i][j + 1] < target){j++;} else if (matrix[i][j + 1] > target && matrix[i + 1][j] < target) {i++;continue;} else if (matrix[i][j + 1] > target && matrix[i + 1][j] > target) {i++;j = 0;}if (j == matrix[0].length) {i++;j = 0;}}return false;
}

http://www.ppmy.cn/server/141705.html

相关文章

Ubuntu22.04安装cuDNN

根据下面地址选择安装即可: 英伟达cuDNN下载 wget https://developer.download.nvidia.com/compute/cudnn/9.5.1/local_installers/cudnn-local-repo-ubuntu2204-9.5.1_1.0-1_amd64.deb sudo dpkg -i cudnn-local-repo-ubuntu2204-9.5.1_1.0-1_amd64.deb sudo cp /var/cudnn-…

Android 开发指南:初学者入门

Android 是全球最受欢迎的移动操作系统之一&#xff0c;为开发者提供了丰富的工具和资源来创建各种类型的应用程序。本文将为你提供一个全面的入门指南&#xff0c;帮助你从零开始学习 Android 开发。 目录 1. 了解 Android 平台[1]2. 设置开发环境[2]3. 学习基础知识[3]4. 创…

什么是上拉和下拉

在电子电路和嵌入式系统中&#xff0c;“上拉”和“下拉”通常指的是上拉电阻&#xff08;pull-up resistor&#xff09;和下拉电阻&#xff08;pull-down resistor&#xff09;。它们是被用于稳定电路输入或输出引脚的电阻器&#xff0c;通过将引脚电位锁定到特定的电压水平来…

资产安全加固的面试点

资产加固 资产管理属于蓝队前期要做的事情&#xff0c;首先客户单位对他自身的单位资产有一定的了解哪些资产的优先级和重要程度等等&#xff0c;所以开始要做相关的资产梳理&#xff0c;对客户单位进行统计&#xff0c;梳理&#xff0c;分析&#xff0c;找到哪些点是可以授权…

vue3实现一个无缝衔接、滚动平滑的列表自动滚屏效果,支持鼠标移入停止移出滚动

文章目录 前言一、滚动元素相关属性回顾一、实现分析二、代码实现示例&#xff1a;2、继续添加功能&#xff0c;增加鼠标移入停止滚动、移出继续滚动效果2、继续完善 前言 列表自动滚屏效果常见于大屏开发场景中&#xff0c;本文将讲解用vue3实现一个无缝衔接、滚动平滑的列表自…

HarmonyOS开发 API 13发布首个Beta版本,部分已知的问题建议处理方案

HarmonyOS 5.0.1 Beta3&#xff0c;是HarmonyOS开发套件基于API 13正式发布的首个Beta版本。该版本在OS能力上主要增强了C API的相关能力&#xff0c;多个特性补充了C API供开发者使用。该版本对部分已知问题做了解决和优化&#xff0c;部分问题给出了解决方案和适配计划&#…

Spring Boot编程训练系统:数据管理与存储

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了编程训练系统的开发全过程。通过分析编程训练系统管理的不足&#xff0c;创建了一个计算机管理编程训练系统的方案。文章介绍了编程训练系统的系统分析部分&…

苍穹外卖day09超出配送范围前端不提示问题

同学们在写苍穹外卖项目day09时调用了百度地图api来判断用户地址是否超出配送范围&#xff0c; 但是在黑马官方的课程或资料中&#xff0c;出现这样的问题时只会向用户端的控制台报错并不会提醒用户 如下图&#xff1a; 解决方法&#xff1a; 其实解决方法很简单只需要找到向…