【算法day8】 Z 字形变换 -O(n)算法思路整理

Z 字形变换,算法思路整理

https://leetcode.cn/problems/zigzag-conversion/description/

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。

比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:

P A H N

A P L S I I G

Y I R

之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"PAHNAPLSIIGYIR"。

请你实现这个将字符串进行指定行数变换的函数:

  • 不擅长打印图形,我将把所有矩阵和一维坐标的映射关系都学习一遍
cpp 复制代码
class Solution {
public:
    string convert(string s, int numRows) {
        int s_len = s.size();
        if (numRows >= s_len || numRows == 1)
            return s;
        int T_length = numRows + numRows - 2;
        string ans;
        for (int i = 0; i < numRows; i++) {
            for (int j = 0; i + j < s_len; j = j + T_length) {
                ans += s[i + j];
                // 不是首行和最后一行的时候,
                if (i > 0 && i < numRows - 1 && j + T_length - i < s_len) {
                    ans += s[j + T_length - i];
                }
            }
        }
        return ans;
    }
};
相关推荐
衡玖16 分钟前
c语言闯算法--常用技巧
c语言·数据结构·算法
Lill_bin24 分钟前
Java中的分布式锁:原理、实现与最佳实践
java·开发语言·数据结构·分布式·算法·排序算法·maven
迷路爸爸18033 分钟前
从零构建逻辑回归: sklearn 与自定义实现对比
算法·逻辑回归·sklearn
*TQK*1 小时前
双指针算法介绍+算法练习(2025)
c++·学习·算法·双指针
陈果然DeepVersion1 小时前
算法奈我何(二)冒泡排序
算法
郭涤生1 小时前
并行算法_第十章_《C++并发编程实战》笔记
c++·算法·并发编程
SomeB1oody2 小时前
【Python机器学习】2.2. 聚类分析算法理论:K均值聚类(KMeans Analysis)、KNN(K近邻分类)、均值漂移聚类(MeanShift)
python·算法·机器学习·聚类·分类算法
Cindy辛蒂2 小时前
C语言:计算并输出三个整数的最大值 并对三个数排序
c语言·数据结构·算法
AI技术控2 小时前
计算机视觉算法实战——驾驶员玩手机检测(主页有源码)
算法·计算机视觉·智能手机
小竹子142 小时前
L2-4 吉利矩阵
算法·矩阵·深度优先