766. 托普利茨矩阵

给你一个 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" 上的元素不同。

提示:

m == matrix.length

n == matrixi.length

1 <= m, n <= 20

0 <= matrixij <= 99

思路:

正常来讲,最直观的做法应该就是第一行的每个元素开始向右下方遍历,看看是否相等;然后再沿着第一列开始向右下方遍历,看看是否相等。

但其实你仔细思考一下,就会发现,不需要这么麻烦,满足题意的最基本的条件,不就是每个元素都跟左上方的元素相等么(如果存在的话)。

而且第一行和第一列是不用判断的,因为不存在左上方元素。

代码:

c 复制代码
class Solution {
public:
    bool isToeplitzMatrix(vector<vector<int>>& matrix) {
        int n = matrix.size();
        int m = matrix[0].size();
        for(int i = 0 ; i < n ; i++){
            for(int j = 0 ; j < m ; j++){
                if(i-1 >= 0 && j-1 >= 0){
                    if(matrix[i-1][j-1] == matrix[i][j])
                        continue;
                    else
                        return false;
                }
            }
        }
        return true;
    }
};
相关推荐
Yiyaoshujuku20 小时前
化合物数据集API接口(数据结构及样例)
java·网络·数据结构
QiLinkOS20 小时前
极客与商业思维的融合实践(1)
c语言·数据库·c++·人工智能·算法·开源协议
fu的博客20 小时前
【数据结构16】图:基于邻接矩阵、邻接表实现DFS/BFS
数据结构·算法
阿正的梦工坊20 小时前
【Rust】17-Send、Sync 与并发安全抽象
算法·安全·rust
hai31524754320 小时前
九章编程法 · HTTP转发代理网关【终极完美版·矩阵步进交换】
人工智能·网络协议·线性代数·http·矩阵·极限编程
plainGeekDev20 小时前
算法刷题笔记:一维DP没那么难,状态想清楚就赢了一半
java·算法·面试
菩提树下的凡夫20 小时前
新版OpenCV5.0在ONNX模型的推理应用
opencv·算法
影寂ldy21 小时前
C# 三大内置委托(Action / Func / Predicate)+ Lambda
c++·算法·c#
机器学习之心21 小时前
小龙虾优化算法(COA)驱动的CNN-LSTM多输出回归模型及其SHAP可解释性分析
算法·cnn·lstm·小龙虾优化算法·cnn-lstm多输出回归·shap可解释性分析
阿正的梦工坊21 小时前
【Rust】13-Trait 系统、动态分发与对象安全
算法·安全·rust