每日一练:LeetCode6 Z 字形变换

题目:
在这里插入图片描述
由题可得是给我们一个字符串和一个指定行数,让我们先把字符排成z字形(从上往下),最后再从左往右读取。因为目前我们知道行数是已知的,所以我们可以使用列表来储存每一排的字符,因为是一个个遍历再添加的,我们可以使用StringBuilder来进行字符串的拼接。
代码如下:

class Solution {
    public String convert(String s, int numRows) {
        // 如果只有一排的话直接返回原字符串
        if(numRows<2){
            return s;
        }
        // 创建一个列表来储存每一排z字形遍历到的字符,每一排的字符用StringBuilder储存,这样也方便后续字符的添加
        List<StringBuilder> lists=new ArrayList<StringBuilder>();
        // 有几排就创建几个StringBuilder
        for(int i=0;i<numRows;i++){
            lists.add(new StringBuilder());           
        }
        // 这里的index是用来摆放z字形顺序时,当前需要摆放字符的坐标
        // flag则是用来让当index遍历到列表头部或者尾部时,需要让index掉头遍历,index的前进与后退与flag的值有关
        int index=0,flag=-1;
        // 遍历s字符串
        for(int i=0;i<s.length();i++){
            // 没有遍历到头或者尾时正常放入
            lists.get(index).append(s.charAt(i));
            // 当遍历到了底部或者头部,需要让index掉头,即flag的值要变
            if(index==0||index==numRows-1){
                flag=-flag;
            }
            index+=flag;
        }
        // 创建一个新的StringBuilder来储存结果
        StringBuilder result=new StringBuilder();
        // 将列表中的字符串在一个个加给result
        for(StringBuilder list:lists){
            result.append(list);
        }
        return result.toString();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值