c语言 - 杨氏矩阵,查找某个数字(思路清晰,代码简洁)(适合刚入坑)

简介: c语言 - 杨氏矩阵,查找某个数字(思路清晰,代码简洁)(适合刚入坑)

杨氏矩阵

题目:

有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的。

请编写程序在这样的矩阵中查找某个数字是否存在。

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

思路:

第一:首先按题目创建一个每行从左到右递增,从上到下是递增的矩阵。
第二:因为时间复杂度小于O(N),所以不能用两个for循环嵌套。要用一个循环。
第三:我们可以从第0行的最后一位元素开始找, 将要查找值与它比较;
第四:查找值大我们就去下一行找(i++),因为这个值已经是本行最大值了;
第五:查找值小我们就往这行前面找(j - -),因为当前值是本行最大值。
找到返回1,未找到返回0.

 

1. //杨氏矩阵
2. //从左到右递增
3. //从上到下递增
4. #include<stdio.h>
5. 
6. int find(int arr[3][3], int row, int col, int key)
7. {
8.  int i = 0;//从第0行
9.  int j = col - 1;//每一行中最后一个元素,也是最大的元素
10.   while (i < row && j >= 0)//条件小于第row行,大于等于第0位
11.   {
12. 
13.     if (key > arr[i][j])
14.       i++;//下一行
15.     else if (key < arr[i][j])
16.       j--;//往前找
17.     else
18.       return 1;
19. 
20.   }
21. 
22. 
23.   return 0;
24. 
25. 
26. }
27. 
28. int main()
29. {
30. 
31.   int arr[3][3] = 
32.   { {1,2,3},
33.     {4,5,6},
34.     {7,8,8}
35.   };
36. 
37.   int ret = find(arr, 3, 3, 7);//用ret来接受函数的返回值
38. 
39.   if (ret == 1)//判断结果
40.   {
41.     printf("find it");
42.   }
43.   else
44.   {
45.     printf("not find");
46.   }
47. 
48. 
49.   return 0;
50. }


相关文章
|
3月前
|
NoSQL 编译器 程序员
【C语言】揭秘GCC:从平凡到卓越的编译艺术,一场代码与效率的激情碰撞,探索那些不为人知的秘密武器,让你的程序瞬间提速百倍!
【8月更文挑战第20天】GCC,GNU Compiler Collection,是GNU项目中的开源编译器集合,支持C、C++等多种语言。作为C语言程序员的重要工具,GCC具备跨平台性、高度可配置性及丰富的优化选项等特点。通过简单示例,如编译“Hello, GCC!”程序 (`gcc -o hello hello.c`),展示了GCC的基础用法及不同优化级别(`-O0`, `-O1`, `-O3`)对性能的影响。GCC还支持生成调试信息(`-g`),便于使用GDB等工具进行调试。尽管有如Microsoft Visual C++、Clang等竞品,GCC仍因其灵活性和强大的功能被广泛采用。
123 1
|
3月前
|
存储 C语言
【C语言】基础刷题训练4(含全面分析和代码改进示例)
【C语言】基础刷题训练4(含全面分析和代码改进示例)
|
1月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
1月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
1月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
2月前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
49 4
|
1月前
|
C语言
C语言练习题代码
C语言练习题代码
|
2月前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
520 6
|
2月前
|
存储 C语言 C++
数据结构基础详解(C语言) 顺序表:顺序表静态分配和动态分配增删改查基本操作的基本介绍及c语言代码实现
本文介绍了顺序表的定义及其在C/C++中的实现方法。顺序表通过连续存储空间实现线性表,使逻辑上相邻的元素在物理位置上也相邻。文章详细描述了静态分配与动态分配两种方式下的顺序表定义、初始化、插入、删除、查找等基本操作,并提供了具体代码示例。静态分配方式下顺序表的长度固定,而动态分配则可根据需求调整大小。此外,还总结了顺序表的优点,如随机访问效率高、存储密度大,以及缺点,如扩展不便和插入删除操作成本高等特点。
196 5
|
2月前
|
存储 C语言
数据结构基础详解(C语言): 栈与队列的详解附完整代码
栈是一种仅允许在一端进行插入和删除操作的线性表,常用于解决括号匹配、函数调用等问题。栈分为顺序栈和链栈,顺序栈使用数组存储,链栈基于单链表实现。栈的主要操作包括初始化、销毁、入栈、出栈等。栈的应用广泛,如表达式求值、递归等场景。栈的顺序存储结构由数组和栈顶指针构成,链栈则基于单链表的头插法实现。
374 3