6、z字形变换

本文介绍了一种将字符串以Z字形排列的算法实现,使用StringBuilder进行高效操作。通过控制方向和行号,将字符分配到指定行,最终合并所有行得到结果。算法的时间复杂度和空间复杂度均为O(n)。

1、题目

(https://img-blog.csdnimg.cn/20200122220245874.png)

2、解法

class Solution {
    public String convert(String s, int numRows) {
       if (numRows == 1) return s;
        // 根据行号,加到了对应的list中
        List<StringBuilder> rows = new ArrayList<>();
        // 行的个数不能超过总长度
        for (int i = 0; i < Math.min(numRows, s.length()); i++) {
            rows.add(new StringBuilder());
        }
        // 当前行号
        int curRow = 0;
        boolean goDown = false;
        for (char c : s.toCharArray()) {
            rows.get(curRow).append(c);
            // 因为当前行号已经为0,加1之后就从1开始,所以提前加
            if (curRow == 0 || curRow == numRows - 1) {
                goDown = !goDown;
            }
            curRow += goDown ? 1 : -1;
        }

        StringBuilder all = new StringBuilder();
        for (StringBuilder row : rows) {
            all.append(row);
        }
        return all.toString();
        }
    }

时间复杂度O(n), 空间复杂度O(n)

3、思考

1、StringBuilder的用法。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值