目录
一、练习题目
1351. 统计有序矩阵中的负数
1572. 矩阵对角线元素的和
1672. 最富有客户的资产总量
766. 托普利茨矩阵
1380. 矩阵中的幸运数
1582. 二进制矩阵中的特殊位置
463. 岛屿的周长
二、答题总结
给你一个 m * n 的矩阵 grid,矩阵中的元素无论是按行还是按列,都以非递增顺序排列。
请你统计并返回 grid 中 负数 的数目。
示例 1:
输入:grid = [[4,3,2,-1],[3,2,1,-1],[1,1,-1,-2],[-1,-1,-2,-3]]
输出:8
解释:矩阵中共有 8 个负数。
示例 2:输入:grid = [[3,2],[1,0]]
输出:0
示例 3:输入:grid = [[1,-1],[-1,-1]]
输出:3
示例 4:输入:grid = [[-1]]
输出:1
class Solution {
public int countNegatives(int[][] grid) {
int sum=0;
for(int i=0;i
给你一个正方形矩阵 mat,请你返回矩阵对角线元素的和。
请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。
示例 1:
输入:mat = [[1,2,3],
[4,5,6],
[7,8,9]]
输出:25
解释:对角线的和为:1 + 5 + 9 + 3 + 7 = 25
请注意,元素 mat[1][1] = 5 只会被计算一次。
示例 2:输入:mat = [[1,1,1,1],
[1,1,1,1],
[1,1,1,1],
[1,1,1,1]]
输出:8
示例 3:输入:mat = [[5]]
输出:5
class Solution {
public int diagonalSum(int[][] mat) {
int n=mat.length;
int sum=0;
for(int i=0;i=0;i--){
sum+=mat[i][n-i-1];
}
if(n%2==1){
sum -= mat[n/2][n/2];
}
return sum;
}
}
给你一个 m x n 的整数网格 accounts ,其中 accounts[i][j] 是第 i 位客户在第 j 家银行托管的资产数量。返回最富有客户所拥有的 资产总量 。
客户的 资产总量 就是他们在各家银行托管的资产数量之和。最富有客户就是 资产总量 最大的客户。
示例 1:
输入:accounts = [[1,2,3],[3,2,1]]
输出:6
解释:
第 1 位客户的资产总量 = 1 + 2 + 3 = 6
第 2 位客户的资产总量 = 3 + 2 + 1 = 6
两位客户都是最富有的,资产总量都是 6 ,所以返回 6 。
示例 2:输入:accounts = [[1,5],[7,3],[3,5]]
输出:10
解释:
第 1 位客户的资产总量 = 6
第 2 位客户的资产总量 = 10
第 3 位客户的资产总量 = 8
第 2 位客户是最富有的,资产总量是 10
示例 3:输入:accounts = [[2,8,7],[7,1,3],[1,9,5]]
输出:17
class Solution {
public int maximumWealth(int[][] accounts) {
int max=0;
int sum=0;
for(int i=0;i
给你一个 m x n 的矩阵 matrix 。如果这个矩阵是托普利茨矩阵,返回 true ;否则,返回 false 。
如果矩阵上每一条由左上到右下的对角线上的元素都相同,那么这个矩阵是托普利茨矩阵 。
示例 1:
输入:matrix = [[1,2,3,4],[5,1,2,3],[9,5,1,2]]
输出:true
解释:
在上述矩阵中, 其对角线为:
"[9]", "[5, 5]", "[1, 1, 1]", "[2, 2, 2]", "[3, 3]", "[4]"。
各条对角线上的所有元素均相同, 因此答案是 True 。
示例 2:
输入:matrix = [[1,2],[2,2]]
输出:false
解释:
对角线 "[1, 2]" 上的元素不同。
class Solution {
public boolean isToeplitzMatrix(int[][] matrix) {
int row = matrix.length;
int col = matrix[0].length;
if(row == 1 || col == 1){
return true;
}
for(int i = 0; i < row - 1; ++i){
for(int j = 0; j < col - 1; ++j){
if(matrix[i][j] != matrix[i + 1][j + 1]){
return false;
}
}
}
return true;
}
}
给你一个 m * n 的矩阵,矩阵中的数字 各不相同 。请你按 任意 顺序返回矩阵中的所有幸运数。
幸运数是指矩阵中满足同时下列两个条件的元素:
在同一行的所有元素中最小
在同一列的所有元素中最大示例 1:
输入:matrix = [[3,7,8],[9,11,13],[15,16,17]]
输出:[15]
解释:15 是唯一的幸运数,因为它是其所在行中的最小值,也是所在列中的最大值。
示例 2:输入:matrix = [[1,10,4,2],[9,3,8,7],[15,16,17,12]]
输出:[12]
解释:12 是唯一的幸运数,因为它是其所在行中的最小值,也是所在列中的最大值。
示例 3:输入:matrix = [[7,8],[1,2]]
输出:[7]
class Solution {
public List luckyNumbers (int[][] matrix) {
int x = matrix[0].length,;
int y = matrix.length;
int[] rowMin = new int[y];
int[] colMax = new int[x];
for (int i = 0; i < y; i++) {
int min = matrix[i][0];
for (int j = 1; j < x; j++) {
min = Math.min(min,matrix[i][j]);
}
rowMin[i] = min;
}
for (int i = 0; i < x; i++) {
int max = matrix[0][i];
for (int j = 1; j < y; j++) {
max = Math.max(max,matrix[j][i]);
}
colMax[i] = max;
}
ArrayList ans = new ArrayList<>();
for (int min : rowMin) {
for (int max : colMax) {
if (max == min)
ans.add(max);
}
}
return ans;
}
}
给你一个大小为 rows x cols 的矩阵 mat,其中 mat[i][j] 是 0 或 1,请返回 矩阵 mat 中特殊位置的数目 。
特殊位置 定义:如果 mat[i][j] == 1 并且第 i 行和第 j 列中的所有其他元素均为 0(行和列的下标均 从 0 开始 ),则位置 (i, j) 被称为特殊位置。
示例 1:
输入:mat = [[1,0,0],
[0,0,1],
[1,0,0]]
输出:1
解释:(1,2) 是一个特殊位置,因为 mat[1][2] == 1 且所处的行和列上所有其他元素都是 0
示例 2:输入:mat = [[1,0,0],
[0,1,0],
[0,0,1]]
输出:3
解释:(0,0), (1,1) 和 (2,2) 都是特殊位置
示例 3:输入:mat = [[0,0,0,1],
[1,0,0,0],
[0,1,1,0],
[0,0,0,0]]
输出:2
示例 4:输入:mat = [[0,0,0,0,0],
[1,0,0,0,0],
[0,1,0,0,0],
[0,0,1,0,0],
[0,0,0,1,1]]
输出:3
class Solution {
public int numSpecial(int[][] mat) {
int row[]=new int[mat.length];
int col[]=new int[mat[0].length];
for(int i=0;i
给定一个 row x col 的二维网格地图 grid ,其中:grid[i][j] = 1 表示陆地, grid[i][j] = 0 表示水域。
网格中的格子 水平和垂直 方向相连(对角线方向不相连)。整个网格被水完全包围,但其中恰好有一个岛屿(或者说,一个或多个表示陆地的格子相连组成的岛屿)。
岛屿中没有“湖”(“湖” 指水域在岛屿内部且不和岛屿周围的水相连)。格子是边长为 1 的正方形。网格为长方形,且宽度和高度均不超过 100 。计算这个岛屿的周长。
示例 1:
输入:grid = [[0,1,0,0],[1,1,1,0],[0,1,0,0],[1,1,0,0]]
输出:16
解释:它的周长是上面图片中的 16 个黄色的边
示例 2:输入:grid = [[1]]
输出:4
示例 3:输入:grid = [[1,0]]
输出:4
class Solution {
public int islandPerimeter(int[][] grid) {
if (grid == null || grid.length == 0) {
return 0;
}
int rsp = 0;
for (int i = 0; i < grid.length; i++) {
for (int j = 0; j < grid[i].length; j++) {
if (grid[i][j] == 1) {
rsp += 4;
if (i > 0 && grid[i - 1][j] == 1) {
rsp -= 2;
}
if (j > 0 && grid[i][j - 1] == 1) {
rsp -= 2;
}
}
}
}
return rsp;
}
}
刷题的感觉真的很爽,虽然随着难度的增加,靠自己的小菜脑不大好像出来,但是一看题解,自己给自己讲一遍,感觉收获了很多,思路这个东西真的是看得多了,做得多了,才会自己在脑子里蹦出来。
for( 变量:集合 )这个加强for循环真的不错,都不用管下标就很不错!