1 Star 0 Fork 0

ZENGWatermelon/LeetCode

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
378.有序矩阵中第k小的元素.py 1.07 KB
一键复制 编辑 原始数据 按行查看 历史
sunzhaoc 提交于 2020-11-24 11:23 . master
'''
Description:
Version: 1.0
Autuor: Vicro
Date: 2020-10-08 19:45:37
LastEditTime: 2020-10-08 20:39:34
FilePath: \Leetcode\Chinese\378.有序矩阵中第k小的元素.py
'''
#
# @lc app=leetcode.cn id=378 lang=python3
#
# [378] 有序矩阵中第K小的元素
#
# @lc code=start
class Solution:
def kthSmallest(self, matrix, k):
l, r = matrix[0][0], matrix[len(matrix) - 1][len(matrix) - 1]
while l < r:
mid = (r - l) // 2 + l
num = self.num_Caculate(matrix, mid)
if num == k and mid in matrix:
return mid
if num < k:
l = mid + 1
else:
r = mid
return l
def num_Caculate(self, matrix, mid):
i = len(matrix) - 1 # Row
j = 0 # Column
num = 0
while i >= 0 and j < len(matrix):
if matrix[i][j] <= mid:
num += i + 1
j += 1
else:
i -= 1
return num
sol = Solution()
A = sol.kthSmallest([[1,5,9],[10,11,13],[12,13,15]], 8)
print(A)
# @lc code=end
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/watermelonTT/LeetCode.git
git@gitee.com:watermelonTT/LeetCode.git
watermelonTT
LeetCode
LeetCode
master

搜索帮助