LeetCode每日一题_3128. 直角三角形

解题思路:

可以先统计每一行和每一列的 1 的个数,记录在数组 rows 和 cols 中。

然后我们枚举每一个 1,假设当前 1 在第 i 行第 j 列,那么以当前 1 为直角三角形的直角点,另外两个直角点分别在第 i 行和第 j 列,那么直角三角形的个数就是 (rows[i]−1)×(cols[j]−1),累加到答案中即可。

java 复制代码
class Solution {
    public long numberOfRightTriangles(int[][] grid) {
        //如果
        int r =grid.length;
        int c =grid[0].length;
        int[] rows = new int[r];
        int[] columns = new int[c];
        for(int i=0;i<r;i++){
            for(int j=0;j<c;j++){
                if(grid[i][j]==1){
                    rows[i]++;
                    columns[j]++;
                }
            }
        }
        long count = 0;//注意如果不使用long型,在遇到大的数字时正数会变成负数。
        for(int i=0;i<r;i++){
            for(int j=0;j<c;j++){
                if(grid[i][j]==1&&(rows[i]>=1)&&(columns[j]>=1)){

                    count+=(long)(rows[i]-1)*(columns[j]-1);
                }
               
            }
        }
        return count;
    }
}
相关推荐
Frostnova丶1 分钟前
(6)LeetCode.42 接雨水
数据结构·算法·leetcode
像污秽一样2 分钟前
算法设计与分析-习题4.4
数据结构·算法·排序算法·深度优先
重庆小透明3 分钟前
【面试问题第一篇】快手后端java一面
java·面试·职场和发展
x_xbx6 分钟前
LeetCode:102. 二叉树的层序遍历
算法·leetcode
2401_889884668 分钟前
嵌入式C++测试框架
开发语言·c++·算法
月明长歌17 分钟前
【码道初阶-Hot100】LeetCode 128. 最长连续序列:从排序双指针扫描到 HashSet,一文讲透为什么 O(n) 解法要用哈希
算法·leetcode·哈希算法
Z9fish22 分钟前
C语言算法专题总结(一)排序
c语言·算法·排序算法
美式请加冰30 分钟前
模拟的介绍和使用
java·开发语言·算法
云泽80835 分钟前
蓝桥杯算法精讲:贪心算法之区间问题深度剖析
算法·贪心算法·蓝桥杯
tankeven36 分钟前
HJ129 小红的双生数
c++·算法