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;
    }
}
相关推荐
ProgramHelpOa3 分钟前
Optiver 2026 OA 全面复盘|26NG / Intern 最新高频题型整理
人工智能·算法·机器学习
feifeigo1233 分钟前
基于无迹变换的电网概率潮流分析 MATLAB 实现
开发语言·算法·matlab
Java成神之路-5 分钟前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋7 分钟前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
Struggle_975514 分钟前
算法知识-倍增算法
算法
计算机安禾17 分钟前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法
fie888920 分钟前
基于遗传算法的机械故障诊断MATLAB程序
算法·机器学习·matlab
nlpming25 分钟前
opencode MCP(Model Context Protocol)配置手册
算法
MATLAB代码顾问37 分钟前
MATLAB实现灰狼算法优化PID参数
算法·机器学习·matlab