python实现杨氏矩阵查找
作者:ZzzMxin 时间:2021-09-28 15:03:26
本文实例为大家分享了python实现杨氏矩阵查找的具体代码,供大家参考,具体内容如下
问题描述:
在一个m行n列二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。有则返回1,无则返回0,输入错误返回input error
问题分析:根据杨氏矩阵的规律可知,左上角是最小元素,右下角是最大元素,进行比较一次只能排除一个。而利用左下角或者右上角对比,一次可以排除一行或一列。
AC代码以右上角为例:
当右上角大于要查找的数字时,排除一行;
当右上角大于要查找的数字时,排除一列;
相等则返回1
全部查找失败则返回0
代码如下:
# coding=utf-8
import sys
def solve():
try:
# 获取行(n)和列(m)
a = sys.stdin.readline().split()
n, m = int(a[0]), int(a[1])
arr = []
for i in range(n):
# 列表模拟二维数组
p = list(map(int, sys.stdin.readline().split()))
arr.append(p)
# 获取要查找的数
s = int(sys.stdin.readline().strip())
i = 0
j = m - 1
while i<n and j>=0:
if arr[i][j] == s:
# 相等返回1查找成功
return 1
elif arr[i][j] < s:
# 小于要查找的元素,行加1
i += 1
else:
# 大于要查找的元素,列加1
j -= 1
return 0
except Exception:
return "input error"
if __name__ == "__main__":
print(solve())
如有疑问,欢迎交流和指正。
来源:https://blog.csdn.net/qq_34178562/article/details/79648265
标签:python,杨氏矩阵,查找
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
通过Pandas读取大文件的实例
2023-12-25 21:18:31
Python实现简易Web爬虫详解
2021-12-11 01:29:16
Python3接口性能测试实例代码
2021-02-16 14:24:18
python使用新浪微博api上传图片到微博示例
2021-10-13 02:15:06
解读Opencv中Filter2D函数的补全方式
2022-06-16 23:11:15
![](https://img.aspxhome.com/file/2023/5/98885_0s.png)
Python 捕获代码中所有异常的方法
2022-08-31 06:44:00
Python测试框架pytest核心库pluggy详解
2023-11-01 23:02:08
Python Opencv实现图像轮廓识别功能
2023-02-27 12:32:40
![](https://img.aspxhome.com/file/2023/6/70696_0s.jpg)
品牌的统一体验
2010-05-19 13:08:00
![](https://img.aspxhome.com/file/UploadPic/20105/19/bue-01-70s.jpg)
Python的argparse库使用详解
2023-06-13 11:27:36
CSS expression在IE8里正式退出历史舞台
2008-10-26 16:57:00
简单代码实现可输入的下拉框功能(select)
2008-10-20 19:52:00
sqlserver 数据库连接字符串中的可选项收集
2011-10-24 19:48:37
pip install python-Levenshtein失败的解决
2023-07-31 05:17:28
![](https://img.aspxhome.com/file/2023/0/118800_0s.png)
python通过smpt发送邮件的方法
2021-06-18 02:50:59
django 发送邮件和缓存的实现代码
2021-05-09 20:53:09
python读取nc数据并绘图的方法实例
2023-09-16 10:08:19
![](https://img.aspxhome.com/file/2023/8/91868_0s.png)
Python3将jpg转为pdf文件的方法示例
2021-06-25 11:31:17
python GUI库图形界面开发之PyQt5动态加载QSS样式文件
2022-09-16 19:50:02
![](https://img.aspxhome.com/file/2023/5/118585_0s.png)
HTTP中header头部信息详解
2023-06-11 23:33:17