R3-新增每日一题打卡。
目录
data:image/s3,"s3://crabby-images/a505d/a505d87b7038a7c331ce24fd549a52d136352579" alt=""
思路:
这题遍历主要从直角点开始遍历,用到了乘法原理。
data:image/s3,"s3://crabby-images/8da66/8da66867872143e2d0e0205211857e85dcf3166a" alt=""
乘法原理如下:
data:image/s3,"s3://crabby-images/5f11f/5f11fbb31ad15266be128e2ccb0071d8030c1455" alt=""
python
class Solution:
def numberOfRightTriangles(self, grid: List[List[int]]) -> int:
#最终结果是(col_sum-1)*(row_sum-1)
#先计算每一列的1之和
col_sum=[sum(col) for col in zip(*grid)]
ret=0
#每一行的
for row in grid:
row_sum=sum(row)
for r,c_s in zip(row,col_sum):
if r==1:
ret+=(row_sum-1)*(c_s-1)
return ret
data:image/s3,"s3://crabby-images/d9f16/d9f16d26521d0cd8519da173ee50d4c95d34e098" alt=""
ps:
python的zip操作
矩阵转置
data:image/s3,"s3://crabby-images/7ff53/7ff533ddfe21d701cf0f8ac3cd3a30c2e01a796d" alt=""
并行遍历
data:image/s3,"s3://crabby-images/6eb83/6eb8348e56ee96d53c107dd19fad34a17355f827" alt=""
对象组合
data:image/s3,"s3://crabby-images/3e646/3e64677e0e9c96a008ea459ce1bf1d09394e3204" alt=""
创建字典
data:image/s3,"s3://crabby-images/a8a39/a8a3957bd95de15595452d44b5cbcd46ad047ea2" alt=""
处理不等迭代长度
data:image/s3,"s3://crabby-images/903f1/903f12ef9116125ee1c8a6e183390e99591768fc" alt=""