【剑斩OFFER】算法的暴力美学——Z字行变换

一、题目描述

二、算法原理

我们可以从字符串的下标表示来寻找题目的规律:

第一行:0 到 4 之间隔着 d = 2 * numrows - 2,相当于数学里面的等差数列的差值 d ,所以:当 i = 0 时,i、i + d、i + 2d、i + 3d 。。。。。i + kd 来表示第一行的取值。

最后一行:其实和第一行一样,i + d 、i + 2d 、i + 3d ......... i + kd 来表示最后一行的取值

中间行:我们把前两个为一组,因为 i + d 求出来的值和第一行和最后一行的求法一样,但是 i + d 前面那个数得 d - i,所以规律为:(i,d - i)、(i + d,2d - i )、(i + 2d,3d - i ).........( i + kd, (k - 1)d - i)。

注意:要注意越界问题,特别是中间行。

三、代码实现

cpp 复制代码
class Solution {
public:
    string convert(string s, int numRows) {
        if(numRows == 1) return s;
        string ret;
        int d = 2 * numRows - 2;
        
        for (int i = 0; i < numRows; i++)
        {
            if(i == 0 || i == numRows - 1)//处理第一行和最后一行
            {
                for(int k = i; k < s.size(); k += d) ret += s[k];
            }
            else//中间
            {
                int tmp = d - i;
                for(int j = i; j < s.size();j += d)
                {
                    ret += s[j];
                    if(tmp < s.size())//防溢出
                    {
                        ret += s[tmp];
                        tmp += d;
                    }
                }
            }
        }
        return ret;
    }
};
相关推荐
折哥的程序人生 · 物流技术专研7 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
想吃火锅10058 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.9 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn9 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫10 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
我爱cope11 小时前
【Agent智能体26 | 多智能体-多智能体工作流】
人工智能·设计模式·语言模型·职场和发展
菜鸟‍11 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
退休倒计时12 小时前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
popcorn_min13 小时前
Digits 手写数字识别:随机森林多分类 + 像素级特征热力图
算法·随机森林·分类
liulilittle13 小时前
拥塞控制:排水终止的两种决策:OR 与 AND
网络·tcp/ip·计算机网络·算法·信息与通信·tcp·通信