【剑斩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;
    }
};
相关推荐
KingRumn2 小时前
Linux信号之标准信号与实时信号
linux·算法
源代码•宸5 小时前
Leetcode—620. 有趣的电影&&Q3. 有趣的电影【简单】
数据库·后端·mysql·算法·leetcode·职场和发展
2301_800256116 小时前
地理空间数据库中的CPU 和 I/O 开销
数据库·算法·oracle
一个不知名程序员www6 小时前
算法学习入门---结构体和类(C++)
c++·算法
阿亮爱学代码8 小时前
Java 面试 (三)
面试·职场和发展
XFF不秃头9 小时前
力扣刷题笔记-旋转图像
c++·笔记·算法·leetcode
王老师青少年编程9 小时前
csp信奥赛C++标准模板库STL案例应用3
c++·算法·stl·csp·信奥赛·lower_bound·标准模版库
有为少年10 小时前
Welford 算法 | 优雅地计算海量数据的均值与方差
人工智能·深度学习·神经网络·学习·算法·机器学习·均值算法
Ven%10 小时前
从单轮问答到连贯对话:RAG多轮对话技术详解
人工智能·python·深度学习·神经网络·算法