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;
    }
}
相关推荐
Paul_09209 分钟前
golang编程题
开发语言·算法·golang
颜酱13 分钟前
用填充表格法-继续吃透完全背包及其变形
前端·后端·算法
夏秃然16 分钟前
打破预测与决策的孤岛:如何构建“能源垂类大模型”?
算法·ai·大模型
氷泠21 分钟前
课程表系列(LeetCode 207 & 210 & 630 & 1462)
算法·leetcode·拓扑排序·反悔贪心·三色标记法
代码or搬砖23 分钟前
JVM垃圾回收器
java·jvm·算法
老鼠只爱大米25 分钟前
LeetCode算法题详解 15:三数之和
算法·leetcode·双指针·三数之和·分治法·three sum
客卿12325 分钟前
C语言刷题--合并有序数组
java·c语言·算法
2301_8008951026 分钟前
hh蓝桥杯每日一题
职场和发展·蓝桥杯
Qhumaing27 分钟前
C++学习:【PTA】数据结构 7-1 实验6-1(图-邻接矩阵)
c++·学习·算法
菜鸟233号40 分钟前
力扣416 分割等和子串 java实现
java·数据结构·算法·leetcode