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;
    }
}
相关推荐
点PY几秒前
《高质量的实时直接体绘制算法》论文精读
算法
X journey2 分钟前
机器学习进阶(24):主成分分析PCA
人工智能·算法·机器学习
MediaTea9 分钟前
AI 术语通俗词典:精确率(分类)
人工智能·算法·机器学习·分类·数据挖掘
Morwit12 分钟前
【力扣hot100】 416. 分割等和子集
数据结构·c++·算法·leetcode·职场和发展
ECT-OS-JiuHuaShan18 分钟前
朱梁整体论,万有代谢元,矛盾因果网,人间正道是沧桑
人工智能·科技·算法·机器学习·拓扑学
qeen8720 分钟前
【算法笔记】二分查找与二分答案
c语言·c++·笔记·学习·算法·二分
C雨后彩虹21 分钟前
投篮大赛问题
java·数据结构·算法·华为·面试
橘白31635 分钟前
GVHMR
人工智能·算法·机器人·机器人数据·视频动捕
宵时待雨36 分钟前
优选算法专题3:二分查找
数据结构·c++·算法·leetcode·职场和发展
代码飞一会儿37 分钟前
算法与数据结构之树——让数据查找更加迅速
算法