每日一道leetcode(2026.03.27):循环移位后的矩阵相似检查

每日一道leetcode(2026.03.27):循环移位后的矩阵相似检查

  • [1. 题目](#1. 题目)
  • [2. 分析](#2. 分析)
  • [3. 代码实现](#3. 代码实现)

1. 题目

给你一个下标从 0 开始且大小为 m x n 的整数矩阵 mat 和一个整数 k 。请你将矩阵中的 奇数 行循环 右 移 k 次,偶数 行循环 左 移 k 次。

如果初始矩阵和最终矩阵完全相同,则返回 true ,否则返回 false 。

示例 1:

输入:mat = [[1,2,1,2],[5,5,5,5],[6,3,6,3]], k = 2

输出:true

解释:

初始矩阵如图一所示。

图二表示对奇数行右移一次且对偶数行左移一次后的矩阵状态。

图三是经过两次循环移位后的最终矩阵状态,与初始矩阵相同。

因此,返回 true 。

2. 分析

今天的题是简单难度,思路可以将每行移动后的元素放到一个新的一维数组,再比较两个数组是否相等,唯一需要注意的是k可以对列数取余,因为移动n次后就回到原来的位置了嘛,取余可以减少运算量。

3. 代码实现

java 复制代码
class Solution {
    public boolean areSimilar(int[][] mat, int k) {
        int col = mat[0].length;
        if (col == 1) {
            // 只有一列时
            return true;
        }
        // 对k求余
        int moveK = k % col;
        if (moveK == 0) {
            return true;
        }
        boolean isEven = true;
        for (int[] ints : mat) {
            isEven = !isEven;
            // 逐行判断
            for (int j = 0; j < col; j++) {
                // 奇数行右移,偶数行左移
                // 计算当前元素在新数组中的索引位置
                int index;
                if (isEven) {
                    index = j - moveK;
                    if (index < 0) {
                        index = col + index;
                    }
                } else {
                    index = j + moveK;
                    if (index > col - 1) {
                        index = index % col;
                    }
                }
                if (ints[index]!=ints[j]){
                    return false;
                }
            }
        }
        return true;
    }
}
相关推荐
白羊by9 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖10 小时前
最大最小值降采样算法的优化
c++·算法
white-persist12 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL162386312913 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
baizhigangqw14 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹14 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_250115 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012315 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
人机与认知实验室15 小时前
如何用四维矩阵建模计算性的态势感知与算计性的势态知感?
人工智能·线性代数·矩阵
编程大师哥15 小时前
C++类和对象
开发语言·c++·算法