每日两题 / 240. 搜索二维矩阵 II && 48. 旋转图像 - 力扣(LeetCode热题100)

240. 搜索二维矩阵 II - 力扣(LeetCode)

从右上角开始搜索,若当前值大于target,向左走,因为当前列的所有值都大于target

若当前值小于target,则当前行向左的所有值小于target,向下走

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m = matrix.size() - 1, n = matrix[0].size() - 1;
        int x = 0, y = n;
        while (x >= 0 && x <= m && y >= 0 && y <= n)
        {
            if (target == matrix[x][y]) return true;
            else if (target < matrix[x][y]) y -- ;
            else x ++ ;
        }
        return false;
    }
};

48. 旋转图像 - 力扣(LeetCode)

讲一个符合我直觉的解法:从外向内,一层层地旋转

每次完成一层中4个数的位置交换,如何得到这4个数的坐标?

每次坐标的变化,方向都是固定的:右下左上

并且每次的曼哈顿距离都是相同的

加上每次向一个方向移动k个曼哈顿距离,但是移动后的坐标"出界",此时就要向另一个方向调整

将出界的曼哈顿距离加到另一个方向上

cpp 复制代码
class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size(), m = matrix[0].size();
        int dx[4] = { 0, 1, 0, -1 }, dy[4] = { 1, 0, -1, 0 };
        int l = 0, r = m - 1, u = 0, d = n - 1;
        int len = m - 1;
        for (int i = 0; i < n / 2; ++ i)
        {
            for (int j = i; j < m - i - 1; ++ j)
            {
                int x = i, y = j;
                int next, cur = matrix[x][y];
                for (int k = 0; k < 4; ++ k)
                {
                    int nx = x + len * dx[k], ny = y + len * dy[k];
                    if (ny > r)
                    {
                        nx += (ny - r);
                        ny = r;
                    }
                    else if (nx > d)
                    {
                        ny -= (nx - d);
                        nx = d;
                    }
                    else if (ny < l)
                    {
                        nx -= (l - ny);
                        ny = l;
                    }
                    else if (nx < u)
                    {
                        ny += (u - nx);
                        nx = u;
                    }
                    x = nx, y = ny;
                    next = matrix[nx][ny];
                    matrix[nx][ny] = cur;
                    cur = next;
                }

            }
            l ++ , r --, u ++ , d -- ;
            len -= 2;
        }
    }
};

// 右下左上
// j+, i+
// i+, j-
// j-, i+
// i-, j+
相关推荐
Zfox_3 小时前
CANN Catlass 算子模板库深度解析:高性能矩阵乘(GEMM)原理、融合优化与模板化开发实践
线性代数·矩阵
历程里程碑4 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
iAkuya5 小时前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展
VT.馒头5 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
Charlie_lll7 小时前
力扣解题-移动零
后端·算法·leetcode
iAkuya7 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
lbb 小魔仙9 小时前
面向 NPU 的高性能矩阵乘法:CANN ops-nn 算子库架构与优化技术
线性代数·矩阵·架构
空白诗9 小时前
CANN ops-nn 算子解读:大语言模型推理中的 MatMul 矩阵乘实现
人工智能·语言模型·矩阵
劈星斩月11 小时前
线性代数-3Blue1Brown《线性代数的本质》特征向量与特征值(12)
线性代数·特征值·特征向量·特征方程
池央12 小时前
ops-nn 算子库中的数据布局与混合精度策略:卷积、矩阵乘法与 RNN 的优化实践
rnn·线性代数·矩阵