矩阵中的“对角线强迫症”:如何优雅地判断Toeplitz矩阵?

举个栗子 🌰

例子1:

矩阵:

复制代码
[6, 7, 8]
[4, 6, 7]
[1, 4, 6]

它的对角线分别是:6,6,6, 7,7, 8, 4,4, 1,每条对角线上的数字都相同,所以它是Toeplitz矩阵 ✅

例子2:

矩阵:

复制代码
[6, 3, 8]
[4, 9, 7]
[1, 4, 6]

主对角线是6,9,6,元素不一样,所以它不是Toeplitz矩阵 ❌

学矩阵的"对角线强迫症"时,光看静态公式总感觉隔靴搔痒?推荐试试图码 网站,它有60+算法动画,能直接把Toeplitz矩阵的判定过程可视化。更绝的是,你可以丢进自定义数据或上传C/C++/Java/Python代码,立马生成专属动画,连AI都能随时解释代码逻辑。这个工具专为408考研高校《数据结构》期末考试 设计,知识点和可运行代码都覆盖了全书级深度。最近复习数据结构算法面试,用它梳理可视化逻辑超顺手。强烈建议去图码体验一把,绝对能帮你打通抽象概念的任督二脉。

图码-数据结构与算法交互式可视化平台

访问网站:https://totuma.cn

解法一:遍历每条对角线(O(n²)时间,O(1)空间)

思路很直接:以第一行和第一列的每个元素为起点,沿着对角线往下检查,确保所有元素都和起点相同。

cpp 复制代码
#include <iostream>
#include<vector>
using namespace std;

bool checkDiagonal(vector<vector<int>> &mat, int x, int y) {
    int n = mat.size(), m = mat[0].size();
    for(int i = x + 1, j = y + 1; i < n && j < m; i++, j++) {
        if(mat[i][j] != mat[x][y])
            return false;
    }
    return true;
}

bool isToeplitz(vector<vector<int>> &mat) {
    int n = mat.size(), m = mat[0].size();
    for(int i = 0; i < m; i++)
        if(!checkDiagonal(mat, 0, i))
            return false;
    for(int i = 0; i < n; i++) 
        if(!checkDiagonal(mat, i, 0))
            return false;
    return true;
}

int main() {
    vector<vector<int>> mat = {
        {6, 7, 8},
        {4, 6, 7},
        {1, 4, 6}
    };
    cout << (isToeplitz(mat) ? "true" : "false");
    return 0;
}

解法二:检查每个元素的左上邻居(O(n²)时间,O(1)空间)

这个解法更简洁!核心思想是:对于矩阵中除了第一行和第一列之外的每个元素,它必须等于它左上角的那个元素。因为对角线上的元素都是通过"向右下移动"连接的。

cpp 复制代码
#include <iostream>
#include<vector>
using namespace std;

bool isToeplitz(vector<vector<int>> &mat) {
    int n = mat.size(), m = mat[0].size();
    for(int i = 1; i < n; i++) {
        for(int j = 1; j < m; j++) {
            if(mat[i][j] != mat[i - 1][j - 1])
                return false;
        }
    }
    return true;
}

int main() {
    vector<vector<int>> mat = {
        {6, 7, 8},
        {4, 6, 7},
        {1, 4, 6}
    };
    cout << (isToeplitz(mat) ? "true" : "false");
    return 0;
}

总结

两种方法的时间复杂度都是O(n²),空间复杂度O(1)。方法一更符合定义,方法二更简洁优雅。推荐使用第二种,代码短且不容易出错。

Toeplitz矩阵在信号处理、数值分析等领域有广泛应用,掌握这个判断方法还是很有必要的哦!

相关推荐
j7~15 小时前
【C++】类和对象(下)--详解之再探构造函数,友元,static成员,类型转换等
开发语言·c++·类型转换·友元·匿名对象·内部类·编译器优化
稷下元歌15 小时前
7天学会plc加机器视觉关于运动控制部份,配套视频在bib
开发语言·c++·git·vscode·python·docker·pip
薇茗15 小时前
【C++】 类与对象 基础篇
开发语言·c++·基础语法·类与对象
A_humble_scholar15 小时前
Linux(三)深入理解 Makefile:自动变量、增量编译原理与文件时间属性
linux·服务器·c++·makefile
沐籽李15 小时前
Proteina-Complexa:NVIDIA 如何把蛋白 Binder 设计推进到全原子生成时代?
大数据·人工智能·算法·英伟达·蛋白质生成
思麟呀15 小时前
C++11并发编程:条件变量
java·linux·jvm·c++·windows
落羽的落羽15 小时前
【项目】JsonRpc框架——开发实现2(业务层)
linux·数据结构·c++·人工智能·算法·json·动态规划
Shadow(⊙o⊙)15 小时前
mkfifo()命名管道-FIFO客户端 服务端模拟。*System V消息队列、信号量(信号灯)。
linux·运维·服务器·开发语言·c++
h_a_o777oah15 小时前
2026 蓝桥杯软件 C++B组 国赛比赛经历及备赛建议
c++·经验分享·算法·蓝桥杯
SHARK_pssm15 小时前
【数据结构——单链表】
数据结构·经验分享·笔记