题目一:使用Java实现二维数组中的查找
考点:数组
题目:二维数组中的查找
描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
方式一:选择从左下角开始搜寻,因为选择在左下角搜寻的话,如果目标值大于搜索值,那么就向右继续搜索,如果目标值小于搜索值,那么就向上继续搜索。在左上角就无法形成这样的判断。时间复杂度为:0(lgn)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | package cn.imooc.java2; public class Solution { public boolean Find( int [][] array, int target) { //定义多维数组的行数 int m = array.length - 1 ; //定义多维数组的列数 int i = 0 ; while (m >= 0 && i < array[ 0 ].length){ if (array[m][i] > target) m--; else if (array[m][i] < target) i++; else return true ; } return false ; } public static void main(String[] args) { Solution s = new Solution(); int [][] b={{ 1 , 2 , 3 },{ 4 , 5 , 6 }}; //测试一个两行三列的数组,目标值为0 System.out.println(s.Find(b, 0 )); } } |
方式二:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | package cn.imooc.java2; public class Test02 { public boolean Find( int [][] array, int target) { //循环输出行 for ( int [] i : array){ //循环输出列 for ( int j : i){ if (j==target){ return true ; } } } return false ; } public static void main(String[] args) { Solution s = new Solution(); int [][] b={{ 1 , 2 , 3 },{ 4 , 5 , 6 }}; System.out.println(s.Find(b, 4 )); } }<br><br> |
优点:方法简单,代码少
确定:时间复杂度为O(n^2),偏高。影响程序的性能。
方式一和方式二涉及到的知识点有:二维数组、算法复杂度、二分查找算法、foreach循环以及二维数组当做形参传入。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?