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;
    }
}
相关推荐
C雨后彩虹1 小时前
任务最优调度
java·数据结构·算法·华为·面试
少林码僧3 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)3 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
Niuguangshuo4 小时前
EM算法详解:解密“鸡生蛋“的机器学习困局
算法·机器学习·概率论
a3158238064 小时前
Android 大图显示策略优化显示(一)
android·算法·图片加载·大图片
一条大祥脚4 小时前
26.1.9 轮廓线dp 状压最短路 构造
数据结构·c++·算法
鲨莎分不晴4 小时前
反向传播的数学本质:链式法则与动态规划的完美共舞
算法·动态规划
sonadorje5 小时前
逻辑回归中的条件概率
算法·机器学习·逻辑回归
cici158745 小时前
基于Pan-Tompkins算法的ECG信号HRV提取方案
算法
McGrady-1755 小时前
拓扑导航 vs 几何导航的具体实现位置
算法