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;
    }
相关推荐
creative_mind10 分钟前
My Greedy Algorithm(贪心算法)之路(一)
c++·算法·贪心算法
阳光男孩0128 分钟前
力扣1546.和为目标值且不重叠的非空子数组的最大数目
数据结构·算法·leetcode
donotdothat1 小时前
D1.排序
数据结构·算法
LabVIEW开发1 小时前
LabVIEW透视变换
算法·计算机视觉·labview·labview开发
迅狐源码工厂1 小时前
如何选择视频号矩阵系统:打造高效短视频内容生态的指南
人工智能·线性代数·矩阵
无敌海苔咪1 小时前
实验六 图像的傅立叶变换
图像处理·算法·计算机视觉·matlab·数字图像处理
惜了梦i1 小时前
【leetcode周赛记录——405】
算法·leetcode·职场和发展
danaaaa2 小时前
算法力扣刷题记录 二十八【225. 用队列实现栈】
数据结构·c++·算法·leetcode·职场和发展
范范08252 小时前
Scikit-learn高级教程:深入理解机器学习算法
算法·机器学习·scikit-learn
wx200411022 小时前
P1392 取数
算法·深度优先