剑指offer之二维数组中查找

简介: 剑指offer之二维数组中查找

1 问题

二维数组中查找:

在一个二维数组钟,每一行都按照从左到右递增得顺序排列,每一列

都按照从上往下得递增排列,请完成一个函数,输入这样得一个二维数组和一个

整数,判断数组是否含有该整数

列如:

1  2  8   9

2  4  9   12

4  7  10  13

6  8  11  15


2 分析

比如我们要找数字7, 我们先从右上角开始分析,如果要找的值比9小,我们在把列向左移动,然后再去把列向左移动,再去找8,然后发现还是比8小,我们依然向左移动,我们再去找到2,然后发现比2大,我们再把行向下移动,找到4,然后我们发现4还是比7小,我们再把行往下移动,以此类推,然后我们发现找到了7.


3 代码实现

#include <stdio.h>
int find(int a[][4], int rows, int  columns, int value)
{
  if (a == NULL || rows <= 0 || columns <= 0)
  {
    return -1;
  }
  int i = 0;
  int j = columns - 1;
  while (i < rows 0 && j >= 0)
  {
    if (a[i][j] == value)
    {
      return 0; 
    }
    else if (a[i][j] > value)
    {
      j--;
    }
    else 
    {
      i++;
    }
  }
  return -1;
}
int find1(int a[][4], int rows, int  columns, int value)
{
  for (int i = 0; i < rows;)
  {
    for (int j = columns - 1; j >=0;)
    {
      if (a[i][j] == value)
      {
        return 0; 
      }
      else if (a[i][j] > value)
      {
        j--;
      }
      else 
      {
        i++;
      }
    }
  }
  return -1;  
}
int main()
{
  int a[4][4] = {{1, 2, 8, 9}, {2, 4, 9 , 12}, {4, 7, 10, 13}, {6, 8, 11, 15}};
  int result1 = find(a, 4, 4, 11);
  int result2 = find(a, 4, 4, 3);
  printf("result1 is %d\n", result1);
  printf("result2 is %d\n", result2);
  int result3 = find(a, 4, 4, 11);
  int result4 = find(a, 4, 4, 3);
  printf("result3 is %d\n", result3);
  printf("result4 is %d\n", result4);
  return 0;
}

4 运行结果

result1 is 0
result2 is -1
result3 is 0
result4 is -1

5 总结

既然我们分析过程会发现行和列都会变,那么我们肯定需要用2个变量去表示行和列,那么我们肯定要找到便利得终止条件,就是变量行不能大于数组真正得行,然后列的话不能小于0,这个问题我一开始用得2个for,然后for里面写了i和j的变化,后面发现不好理解,然后如果以后我们只要涉及到for里面得i和j更加实际情况需要动态变化的,我们就不要用2个for循环了,我们直接用while(终止条件) {i变化,j变化}里面改变i和j的值,也就是在while循环里面直接操刀i和j,一定要记住。


 


相关文章
|
4天前
|
云安全 监控 安全
|
2天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1164 7
|
11天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
734 42
|
15天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1176 41
|
15天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
942 78
大厂CIO独家分享:AI如何重塑开发者未来十年
|
3天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
|
2天前
|
人工智能 JSON 前端开发
为什么你的API文档总是被吐槽?用这份"契约指令"终结前后端战争
本文针对前后端协作中"文档过时、不准确"的痛点,提供了一套实战验证的AI指令。通过强制结构化输入和自检机制,让AI自动生成包含完整参数、JSON示例和多语言代码的标准API契约文档,彻底解决接口沟通难题。
173 112
|
11天前
|
存储 自然语言处理 测试技术
一行代码,让 Elasticsearch 集群瞬间雪崩——5000W 数据压测下的性能避坑全攻略
本文深入剖析 Elasticsearch 中模糊查询的三大陷阱及性能优化方案。通过5000 万级数据量下做了高压测试,用真实数据复刻事故现场,助力开发者规避“查询雪崩”,为您的业务保驾护航。
562 32