香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

python实现杨氏矩阵查找


时间:2022-04-02 10:21 作者:admin610456


本文实例为大家分享了python/' target='_blank'>python实现杨氏矩阵查找的具体代码,供大家参考,具体内容如下

问题描述:

在一个m行n列二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。有则返回1,无则返回0,输入错误返回input error

问题分析:根据杨氏矩阵的规律可知,左上角是最小元素,右下角是最大元素,进行比较一次只能排除一个。而利用左下角或者右上角对比,一次可以排除一行或一列。

AC代码以右上角为例:

当右上角大于要查找的数字时,排除一行; 当右上角大于要查找的数字时,排除一列; 相等则返回1 全部查找失败则返回0

代码如下:

# coding=utf-8import sysdef 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())

如有疑问,欢迎交流和指正。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)