《剑指offer》面试题13:二维子矩阵的数字之和

"""
题目:输入一个二维矩阵,如何计算给定左上角坐标和右下角坐标的子矩阵之和?
     例如输入下面的二维矩阵,以及左上角坐标为(2,1)和右下角坐标为(4,3)的子矩阵,该函数输出8
解答思路:书上的答案还是繁琐,可能是因为使用Java的原因吧,对于python而言,将数组的每行视为一个子列表,
        然后使用列表切片功能,对每个子列表切片求和即可
"""

t = [
    [3, 0, 1, 4, 2],
    [5, 6, 3, 2, 1],
    [1, 2, 0, 1, 5],
    [4, 1, 0, 1, 7],
    [1, 0, 3, 0, 5]
]
location_start = (2, 1)
location_end = (4, 3)


def numpy_summary(t, start, end):
    start_x, start_y = start
    end_x, end_y = end
    summary = 0
    for k in range(end_x-start_x+1):
        sub_summary = sum(t[start_x+k][start_y:end_y+1])
        summary += sub_summary
    return summary


summary = numpy_summary(t, location_start, location_end)
print(summary)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值