【算法】模拟算法——Z字形变换(medium)

题解:模拟算法------Z字形变换(medium)

目录

1.题目

题目链接:LINK

2.题解

利用模拟,来解决问题。

首先创建出一个O(numRows*n)的数组来,并按照题目要求把每个字符按顺序填进去。

这里以numRows = 4,字符串s = "abcdefghijk"为例来演示如下:

然后我们按每行挨个把字符加进去就行了,除了很浪费空间...

所以,我们可以总结规律来进行优化:

规律可以分为两部分:

第一部分是第一行和最后一行 ,满足如下特点:
下标从numRows-1开始,且后一个比前一个多d

第二部分是中间那些行 ,满足如下特点:
两两一组,下标从{k,d-k}开始,下一组比前一组多d

图解如下:

3.参考代码

cpp 复制代码
class Solution {
public:
    string convert(string s, int numRows) {
        if(numRows == 1) return s;

        int n = s.size();
        string ret;
        int d = 2*numRows - 2;
        
        //先处理第一行
        for(int i = 0; i < n; i+=d)
        {
            ret+=s[i];
        }
        //再处理中间一行
        for(int i = 1; i < numRows - 1; i++)//标识行
        {
            for(int j = i,k = d-i;j < n || k < n;j+=d,k+=d)//这个地方为什么用||来判定是否结束?防止一个条件满足了,另一个不满足从而导致漏字符的情况
            {
                if(j < n) ret+=s[j];//上面判断结束条件有可能是越界的,因而在加入之前应该先判断一下
                if(k < n) ret+=s[k];
            }
        }
        //处理最后一行
        for(int i = numRows-1; i < n; i+=d)
        {
            ret+=s[i];
        }

        return ret;
    }
};

4.总结

大部分的模拟题如果要做优化,大概就是去找其中的规律。


EOF

相关推荐
_fairyland几秒前
数据结构 力扣 练习
数据结构·考研·算法·leetcode
LIZhang201615 分钟前
基于ffmpeg8.0录制mp4文件
开发语言·c++
Neil今天也要学习19 分钟前
永磁同步电机无速度算法--基于三阶LESO的反电动势观测器
算法·1024程序员节
_OP_CHEN22 分钟前
C++进阶:(九)深度剖析unordered_map 与 unordered_set容器
开发语言·c++·stl容器·哈希表·哈希桶·unordered_map·unordered_set
机器学习之心29 分钟前
NGO-VMD北方苍鹰算法优化变分模态分解+皮尔逊系数+小波阈值降噪+信号重构,MATLAB代码
算法·matlab·重构·信号重构·ngo-vmd·皮尔逊系数·小波阈值降噪
橘颂TA33 分钟前
【剑斩OFFER】算法的暴力美学——山脉数组的蜂顶索引
算法·leetcode·职场和发展·c/c++
速易达网络1 小时前
C语言常见推理题
java·c语言·算法
freedom_1024_1 小时前
LRU缓存淘汰算法详解与C++实现
c++·算法·缓存
博语小屋1 小时前
力扣11.盛水最多的容器(medium)
算法·leetcode·职场和发展
无敌最俊朗@1 小时前
C++-Qt-音视频-基础问题01
开发语言·c++