C语言 | Leetcode C语言题解之第378题有序矩阵中第K小的元素

题目:

题解:

cpp 复制代码
bool check(int **matrix, int mid, int k, int n) {
    int i = n - 1;
    int j = 0;
    int num = 0;
    while (i >= 0 && j < n) {
        if (matrix[i][j] <= mid) {
            num += i + 1;
            j++;
        } else {
            i--;
        }
    }
    return num >= k;
}

int kthSmallest(int **matrix, int matrixSize, int *matrixColSize, int k) {
    int left = matrix[0][0];
    int right = matrix[matrixSize - 1][matrixSize - 1];
    while (left < right) {
        int mid = left + ((right - left) >> 1);
        if (check(matrix, mid, k, matrixSize)) {
            right = mid;
        } else {
            left = mid + 1;
        }
    }
    return left;
}
相关推荐
爱编码的小八嘎21 分钟前
第3章 Windows运行机理-3.1 内核分析(4)
c语言
努力学算法的蒟蒻23 分钟前
day90(2.19)——leetcode面试经典150
算法·leetcode·面试
踩坑记录32 分钟前
leetcode hot100 22. 括号生成 medium 递归回溯
leetcode
样例过了就是过了35 分钟前
LeetCode热题100 缺失的第一个正数
数据结构·算法·leetcode
样例过了就是过了37 分钟前
LeetCode热题100 除了自身以外数组的乘积
数据结构·算法·leetcode
智者知已应修善业44 分钟前
【蓝桥杯单词分析最多字母次数并列字典最小输出】2025-4-15
c语言·c++·经验分享·笔记·算法·蓝桥杯
爱编码的小八嘎6 小时前
第3章 Windows运行机理-3.1 内核分析(2)
c语言
v_for_van10 小时前
力扣刷题记录7(无算法背景,纯C语言)
c语言·算法·leetcode
白太岁10 小时前
通信:(3) 高并发网络通信:epoll + 边沿触发 + 非阻塞 IO + tcp
c语言·网络·c++·网络协议·tcp/ip
We་ct13 小时前
LeetCode 105. 从前序与中序遍历序列构造二叉树:题解与思路解析
前端·算法·leetcode·链表·typescript