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;
    }
};
相关推荐
阿正的梦工坊1 天前
【Rust】03-所有权、移动与复制
开发语言·算法·rust
一切皆是因缘际会1 天前
因果推理人工智能
大数据·数据结构·人工智能
好评笔记1 天前
深度学习面试八股—— GRU(Gated Recurrent Unit)
人工智能·rnn·深度学习·算法·机器学习·gru·校招
搞科研的小刘选手1 天前
【智能计算方向专题研讨会】第三届智能计算与数据分析国际学术会议(ICDA 2026)
大数据·算法·机器学习·数据挖掘·数据分析·可视化·计算
量化君也1 天前
桥水基金全天候策略拆解,构建中国ETF躺平版策略
大数据·人工智能·python·算法·金融·业界资讯
蓦然回首却已人去楼空1 天前
画图专用文档
算法
洛水水1 天前
【力扣100题】78.在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
江屿风1 天前
C++图论基础拓扑排序算法流食般投喂
开发语言·c++·笔记·算法·排序算法
海棠AI实验室1 天前
AI 时代文献综述:从检索到成稿的 RAG 五步法
windows·算法·自动化·llm·rag
H178535090961 天前
SolidWorks_基于草图的实体特征14_扫描扭转与控制
前端·人工智能·算法·3d建模·solidworks