LeetCode-6-Z 字形变换

monigo · · 76 次点击 · · 开始浏览    

题目描述

Z 字形变换

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

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

L   C   I   R
E T O E S I I G
E   D   H   N

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

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

string convert(string s, int numRows);

示例 1:

输入: s = "LEETCODEISHIRING", numRows = 3
输出: "LCIRETOESIIGEDHN"

示例 2:

输入: s = "LEETCODEISHIRING", numRows = 4
输出: "LDREOEIIECIHNTSG"
解释:

L     D     R
E   O E   I I
E C   I H   N
T     S     G

思路

创建一个长度为numRows的字符串数组,每个字符串存储排列中一行的元素,然后重复执行数组的插入操作,直到输入都插入完毕。
以示例2解释为例,在第一组循环中依次插入L-E-E-T-C-O,第二组D-EI-S-H-I,以此类推。

Code

  • Golang
func convert(s string, numRows int) string {
    arr := make([]string, numRows)
    idx := 0
    l := len(s)
    for idx < l {
        i := 0
        for ;i<numRows;i++ {
            arr[i] += string(s[idx])
            idx++
            if idx == l {
                goto sum
            }
        }
        for i-=2 ; i > 0; i-- {
            arr[i] += string(s[idx])
            idx++
            if idx == l {
                goto sum
            }
        }
    }

    sum:
    return strings.Join(arr, "")
}

本文来自:简书

感谢作者:monigo

查看原文:LeetCode-6-Z 字形变换

入群交流(该群和以上内容无关):Go中文网 QQ交流群:798786647 或 加微信入微信群:274768166 备注:入群; 公众号:Go语言中文网

76 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传