LeetCode 面试经典150题 Z字形变换

题目

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

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

复制代码
P   A   H   N
A P L S I I G
Y   I   R

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

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

复制代码
string convert(string s, int numRows);

思路

代码

java 复制代码
class Solution {
    public String convert(String s, int numRows) {
        if (numRows == 1) 
            return s;
        int len = Math.min(s.length(), numRows);
        String[] rows = new String[len];
        for (int i = 0; i < len; i++)
            rows[i] = "";
        int loc = 0;
        boolean down = false;

        for (int i = 0; i < s.length(); i++) {
            rows[loc] += s.substring(i, i + 1);
            if (loc == 0 || loc == numRows - 1) // 因为是Z字形,所以从上往下再从下往上
                down = !down;
            loc += down ? 1 : -1;
        }
                
        String ans = "";
        for (String row : rows) {
            ans += row;
        }
        return ans;
    }
}

性能

时间复杂度o(n)

空间复杂度o(n)

相关推荐
Dave.B8 分钟前
vtkPolyDataConnectivityFilter 实用指南
算法·vtk
细节处有神明37 分钟前
开源数据之历史气象数据的获取与使用
人工智能·python·算法
小白开始进步1 小时前
JAKA Zu12 机械臂运动学算法深度解析(含可视化方案)
python·算法·numpy
梵刹古音1 小时前
【C语言】 递归函数
c语言·数据结构·算法
岁岁种桃花儿1 小时前
SpringCloud超高质量面试高频题300道题
spring·spring cloud·面试
yongui478341 小时前
混凝土二维随机骨料模型 MATLAB 实现
算法·matlab
酉鬼女又兒1 小时前
JAVA牛客入门11~20
算法
努力学算法的蒟蒻1 小时前
day75(2.3)——leetcode面试经典150
面试·职场和发展
代码游侠2 小时前
C语言核心概念复习(二)
c语言·开发语言·数据结构·笔记·学习·算法