当前位置: 首页 > news >正文

C语言初阶习题【29】杨氏矩阵

1. 题目描述——杨氏矩阵

有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,请编写程序在这样的矩阵中查找某个数字是否存在。

要求:时间复杂度小于O(N);

2. 思路

在这里插入图片描述

3. 代码实现1

#include<stdio.h>void find_k(int arr[3][3], int row, int col, int k)
{int x = 0;int y = col-1;int flag = 0;while(x <= row - 1 && y >= 0) //行一直增加,但是最大是2,列一直减少,但是最小是0,如果超过这个范围就超出数组范围了{if (k > arr[x][y]){x++;}else if (k < arr[x][y]){y--;}else{printf("找到了,下标是:%d,%d\n",x,y);flag = 1;break;}}if(flag==0)printf("没找到\n");
}int main()
{int arr[3][3] = { 1,2,3,4,5,6,7,8,9 };int k = 7;find_k(arr, 3, 3,k);return 0;
}

在这里插入图片描述

4. 代码实现2

在代码实现1的基础上进行改进,我们把找到元素的下标,也返回出来
这里涉及到我们的函数只有一个返回值,所以我们使用指针来把我们的下标带回来

#include<stdio.h>int find_k(int arr[3][3], int *row, int *col, int k)
{int x = 0;int y = *col - 1;while (x <= *row - 1 && y >= 0) //行一直增加,但是最大是2,列一直减少,但是最小是0,如果超过这个范围就超出数组范围了{if (k > arr[x][y]){x++;}else if (k < arr[x][y]){y--;}else{*row = x;*col = y;return 1;}}return 0;
}int main()
{int arr[3][3] = { 1,2,3,4,5,6,7,8,9 };int k = 7;int row = 3;int col = 3;int ret = find_k(arr, &row, &col, k);if (ret == 0){printf("找不到!\n");}else{printf("找到了,数组下标为(%d,%d)", row, col);}return 0;
}

在这里插入图片描述

http://www.lryc.cn/news/522178.html

相关文章:

  • [操作系统] 深入理解操作系统的概念及定位
  • Java中对list数据进行手动分页(可直接复用版)
  • 【HarmonyOS NEXT】鸿蒙跳转华为应用市场目标APP下载页
  • 《研发管理 APQP 软件系统》——汽车电子行业的应用收益分析
  • 【IDEA 2024】学习笔记--文件选项卡
  • Android SystemUI——服务启动流程(二)
  • iOS - 内存对齐
  • 小游戏前端地区获取
  • AIGC时代:如何快速搞定Spring Boot+Vue全栈开发
  • MDX语言的多线程编程
  • Vue.js组件开发-实现输入框与筛选逻辑
  • 配置Allure环境变量【macOS版】
  • AndroidStudio升级到2024.2.2项目AGP升级8.8.0版本记录
  • Require:利用MySQL binlog实现闪回操作
  • 计算机网络 (40)域名系统DNS
  • UE5游戏性能优化指南
  • Gitlab Runner安装与配置
  • 如何有效防止和解决IP劫持问题
  • 2006-2020年各省人均水资源量数据
  • C++基础入门(二)
  • 互联网架构困境:网络与信息安全
  • HIVE技术
  • RustDesk ID更新脚本
  • 卷积神经网络的底层是傅里叶变换
  • Bootstrap 下拉菜单
  • 计算机组成原理(计算机系统3)--实验一:WinMIPS64模拟器实验
  • 读书笔记~管理修炼-风险性决策:学会缩小风险阈值
  • VIVADO FIFO (同步和异步) IP 核详细使用配置步骤
  • tcp粘包原理和解决
  • C语言预处理艺术:编译前的魔法之旅