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. }


相关文章
|
1月前
|
存储 安全 数据管理
C语言之考勤模拟系统平台(千行代码)
C语言之考勤模拟系统平台(千行代码)
55 4
|
4月前
|
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仍因其灵活性和强大的功能被广泛采用。
152 1
|
26天前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
1月前
|
存储 安全 物联网
C语言物联网开发之设备安全与代码可靠性隐患
物联网设备的C语言代码安全与可靠性至关重要。一是防范代码安全漏洞,包括缓冲区溢出和代码注入风险,通过使用安全函数和严格输入验证来预防。二是提高代码跨平台兼容性,利用`stdint.h`定义统一的数据类型,并通过硬件接口抽象与适配减少平台间的差异,确保程序稳定运行。
|
27天前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
60 1
|
2月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
2月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
2月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
3月前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
62 4
|
2月前
|
C语言
C语言练习题代码
C语言练习题代码