leetcode 二分查找·系统掌握 统计有序矩阵中的负数

题目:

给你一个 m * n 的矩阵 grid,矩阵中的元素无论是按行还是按列,都以非严格递减顺序排列。 请你统计并返回 grid负数 的数目。

题解:

一种可行的解题思路是找出每一行中负数的个数再相加,又因为每一行单调递减,我们查找的又是负数,所以使用和上一题一样的泛型二分~01~模型,把每一行的结果相加即可。

cpp 复制代码
 int countNegatives(vector<vector<int>>& grid) {
        int ans=0;
        for(int i=0;i<grid.size();i++){
            int l=0,r=grid[0].size()-1;
            while(l<r){
                int mid=(l+r)>>1;
                if(grid[i][mid]<0)r=mid;
                else l=mid+1;
            }
            if(grid[i][l]<0)ans+=grid[0].size()-l;
        }
        return ans;
    }
相关推荐
岛雨QA12 小时前
递归「Java数据结构与算法学习笔记5」
数据结构·算法
kebijuelun12 小时前
Learning Personalized Agents from Human Feedback:用人类反馈训练可持续个性化智能体
人工智能·深度学习·算法·transformer
Eloudy13 小时前
稀疏矩阵的 CSR 格式(Compressed Sparse Row)
人工智能·算法·arch·hpc
岛雨QA13 小时前
栈「Java数据结构与算法学习笔记4」
数据结构·算法
乐观勇敢坚强的老彭13 小时前
c++寒假营day05
开发语言·c++·算法
重生之后端学习13 小时前
74. 搜索二维矩阵
开发语言·数据结构·算法·职场和发展·深度优先
JYeontu13 小时前
程序员都该掌握的“质因数分解”
前端·javascript·算法
with-the-flow13 小时前
从数学底层的底层原理来讲 random 的函数是怎么实现的
c语言·python·算法
tyb33333313 小时前
leetcode:吃苹果和队列
算法·leetcode·职场和发展
多恩Stone13 小时前
【3D-AICG 系列-15】Trellis 2 的 O-voxel Shape: Flexible Dual Grid 代码与论文对应
人工智能·python·算法·3d·aigc