当前位置: 首页 > news >正文

【力扣】3128. 直角三角形 JAVA

一、题目描述

给你一个二维 boolean 矩阵 grid 。
请你返回使用 grid 中的 3 个元素可以构建的 直角三角形 数目,且满足 3 个元素值 都 为 1 。
注意:
如果 grid 中 3 个元素满足:一个元素与另一个元素在 同一行,同时与第三个元素在 同一列 ,那么这 3 个元素称为一个 直角三角形 。这 3 个元素互相之间不需要相邻。

  • 示例 1:
    0 1 0
    0 1 1
    0 1 0
    输入:grid = [[0,1,0],[0,1,1],[0,1,0]]
    输出:2
    解释:
    有 2 个直角三角形。

  • 示例 2:
    1 0 0 0
    0 1 0 1
    1 0 0 0
    输入:grid = [[1,0,0,0],[0,1,0,1],[1,0,0,0]]
    输出:0
    解释:
    没有直角三角形。

  • 示例 3:
    1 0 1
    1 0 0
    1 0 0
    输入:grid = [[1,0,1],[1,0,0],[1,0,0]]
    输出:2
    解释:
    有两个直角三角形。

二、解题思路

/***  解题思路:*  1、因为要找直角三角形,也就是说我们要找直角的顶点,也就是数组的交点为1*  2、先判断交点为1,然后找到交点为1所在的行的1的个数,然后再找到交点为1所在的列的1的个数*  3、解决第2步的问题,我们可以将二维数组的行和列抽取出来成为两个一维数组*  4、最后将每一行1的个数减去1 乘以 每一列1个数减1 最终得到结果(这个减去的1就是交点位置的1)*/

三、示例代码

public static long numberOfRightTriangles(int[][] grid) {//结果long sum = 0;//行数int m = grid.length;//列数int n = grid[0].length;//一维数组行int[] row = new int[m];//一维数组列int[] col = new int[n];for (int i = 0; i < m; i ++) {for (int j = 0; j < n; j ++) {//每行的j个数字相加,和为几,就代表每行有几个1row[i] += grid[i][j];//每列的i个数字相加,和为几,就代表每列有几个1col[j] += grid[i][j];}}for (int i = 0; i < m; i ++) {for (int j = 0; j < n; j ++) {//判断交点为1if (grid[i][j] == 1) {//将每一行1的个数减去1 乘以 每一列1个数减1 最终得到结果sum += (row[i] - 1) * (col[j] - 1);}}}return sum;}public static void main(String[] args) {int[][] grid = {{0,1,0},{0,1,1},{0,1,0}};System.out.println(numberOfRightTriangles(grid));}
http://www.lryc.cn/news/412823.html

相关文章:

  • 如何全面提升企业安全意识
  • 全球支持与无界服务:跨越地域的数据采集与分析
  • Java面试八股之简述spring boot的目录结构
  • python == 与 is区别
  • STM32学习笔记1---LED,蜂鸣器
  • 动手学强化学习 第 15 章 模仿学习 训练代码
  • 第一阶段面试问题(前半部分)
  • 《数学教学通讯》是一本怎样的刊物?投稿难吗?
  • <机器学习> K-means
  • 我们如何优化 Elasticsearch Serverless 中的刷新成本
  • MySQL半同步复制
  • [一本通提高数位动态规划]数字游戏:取模数题解
  • [Day 39] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • OpenStack入门体验
  • 预测未来 | MATLAB实现RF随机森林多变量时间序列预测未来-预测新数据
  • iOS 系统提供的媒体资源选择器(UIImagePickerController)
  • 电脑如何扩展硬盘分区?告别空间不足困扰
  • 论文阅读:Mammoth: Building math generalist models through hybrid instruction tuning
  • 什么样的双筒式防爆器把煤矿吸引?
  • 如何保证冰河AL0 400G 100W 的稳定运行?
  • 剪画小程序:巴黎奥运会,从画面到声音!
  • 【leetcode详解】心算挑战: 一题搞懂涉及奇偶数问题的 “万金油” 思路(思路详解)
  • 【资料集】数据库设计说明书(Word原件提供)
  • MySQL 常用查询语句精粹
  • hive的内部表(MANAGED_TABLE)和外部表(EXTERNAL_TABLE)的区别
  • 【AutoSar网络管理】验证ecu能够从RepeatMessage状态切换到ReadySleep
  • js逻辑或(||)和且()
  • ElasticSearch入门(六)SpringBoot2
  • vue项目Nginx部署启动
  • Duplicate class kotlin.collections.jdk8.CollectionsJDK8Kt found in modules。Android studio纯java代码报错