【LeetCode刷题】6. Z 字形变换

  • [1. 题目链接](#1. 题目链接)
  • [2. 题目描述](#2. 题目描述)
  • [3. 解题方法](#3. 解题方法)
  • [4. 代码](#4. 代码)

1. 题目链接

6. Z 字形变换

2. 题目描述

3. 解题方法

假设一串字符串"abcdefghijklmnopqrstuvwx", 会有如下排列:

我们再以下标来看看排列

从下标来看,每个下标是有规律的

  1. 每一行的下标之间的差值都为6,那么我就设他们之前存在一个公差
  2. 求出公差公式,d = 2 * numRows - 2
  3. 根据公差公式,即可对每一行进行填写

第1行, (0) => 0 + d => 0 + 2d => ......

中间行, (k, d - k) => (k + d, d - k + d) = > (k + 2d, d - k + 2d) => ......

最后1行,(numRows)=> (numRows + d) => (numsRows + 2d) => ......

根据上面推出的式子,即可写出代码模拟。

4. 代码

cpp 复制代码
class Solution {
public:
    string convert(string s, int numRows) 
    {
        if(numRows == 1) return s;
        string ret;
        int n = s.size();
        int d = 2 * numRows - 2;
        // 1. 处理第一行
        for(int i = 0; i < n; i += d)
        {
            ret += s[i];
        }
        // 2. 处理中间行
        for(int k = 1; k < numRows - 1; k++)
        {
            for(int i = k, j = d - k; i < n || j < n; i += d, j += d)
            {
                if(i < n) ret += s[i];
                if(j < n) ret += s[j];
            }
        }
        // 3. 处理最后一行
        for(int i = numRows - 1; i < n; i += d)
        {
            ret += s[i];
        }
        return ret;
    }
};

最后附上我的打卡记录,希望各位大佬可以监督我。

相关推荐
狐571 小时前
2026-01-22-LeetCode刷题笔记-3507-移除最小数对使数组有序I
笔记·leetcode
充值修改昵称1 小时前
数据结构基础:B树磁盘IO优化的数据结构艺术
数据结构·b树·python·算法
程序员-King.7 小时前
day158—回溯—全排列(LeetCode-46)
算法·leetcode·深度优先·回溯·递归
月挽清风8 小时前
代码随想录第七天:
数据结构·c++·算法
小O的算法实验室8 小时前
2026年AEI SCI1区TOP,基于改进 IRRT*-D* 算法的森林火灾救援场景下直升机轨迹规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小郭团队9 小时前
2_1_七段式SVPWM (经典算法)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·硬件架构·arm·dsp开发
充值修改昵称9 小时前
数据结构基础:从二叉树到多叉树数据结构进阶
数据结构·python·算法
Deepoch9 小时前
Deepoc数学大模型:发动机行业的算法引擎
人工智能·算法·机器人·发动机·deepoc·发动机行业
浅念-10 小时前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
Hcoco_me10 小时前
大模型面试题84:是否了解 OpenAI 提出的Clip,它和SigLip有什么区别?为什么SigLip效果更好?
人工智能·算法·机器学习·chatgpt·机器人