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;
    }
相关推荐
handler014 分钟前
基础算法:BFS
开发语言·数据结构·c++·学习·算法·宽度优先
2401_879503415 分钟前
C++中的状态模式实战
开发语言·c++·算法
不当菜鸡的程序媛6 分钟前
神经网络——bias 偏置项(bias term) 或者截距项(intercept term)
人工智能·神经网络·算法
Aawy1206 分钟前
自定义字面量实战
开发语言·c++·算法
无尽的罚坐人生8 分钟前
hot 100 200. 岛屿数量
算法·dfs
j_xxx404_12 分钟前
LeetCode模拟算法精解II:外观数列与数青蛙
数据结构·c++·算法·leetcode
牢姐与蒯12 分钟前
字符串相乘
算法
得物技术13 分钟前
大禹平台:流批一体离线Dump平台的设计与应用|得物技术
java·后端·算法
2301_7938046924 分钟前
C++与硬件交互编程
开发语言·c++·算法
像污秽一样27 分钟前
算法设计与分析-习题9.2
数据结构·算法·排序算法·dfs