代码编织梦想

题目:

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"PAHNAPLSIIGYIR"。请你实现这个将字符串进行指定行数变换的函数:

示例:

示例 1:

输入:s = "PAYPALISHIRING", numRows = 3
输出:"PAHNAPLSIIGYIR"

示例 2:

输入:s = "PAYPALISHIRING", numRows = 4
输出:"PINALSIGYAHRPI"
解释:

示例 3:

输入:s = "A", numRows = 1
输出:"A"

提示:

1 <= s.length <= 1000

s 由英文字母(小写和大写)、',' 和 '.' 组成

1 <= numRows <= 1000

图解:

返回:"LC"+"ET"+"OED"

代码+解题思路:

 public String convert(String s, int numRows) {
        if (numRows < 2) {
            return s;//如果只有一行输出就直接返回s
        }
        //创建集合,它里面的内容是一个StringButter类型
        //使用StringButter是为了方便字符串每一部分的拼接
        List<StringBuilder> list = new ArrayList<>();
        for (int i = 0; i < numRows; i++) {
            list.add(new StringBuilder());
        }//每个位置都是 StringBuilder
        int index = 0, flag = -1;
        for (char c : s.toCharArray()) {//遍历s,遍历结果为字符类型
            String s1 = Character.toString(c);//将字符类型转换为字符串类形
            list.get(index).append(s1);//在index索引位置拼接s1
            if (index == 0 || index == numRows - 1) {
                flag = -flag;//转折点flag要变号
            }
            index = index + flag;//下一个字符存储的集合位置
        }
        String res = new String();
        for (int i = 0; i < list.size(); i++) {
            res += list.get(i);//将集合的每一部分全部拼接在一起
        }
        return res;//最终返回拼接后的字符串
    }

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ziyourufen/article/details/135750371

leetcode第6题,z字形变换_weixin_38288365的博客-爱代码爱编程

leetCode第6题,Z字形变换 class Solution(object): def convert(self, s, numRows): “”" :type s: str :type numRows: int :r

leetcode 第六题 z字形变换-爱代码爱编程

leetcode 第六题 Z字形变换 题目描述 将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 “LEETCODEISHIRING” 行数为 3 时,排列如下: 题目来

LeetCode--Z 字形变换-爱代码爱编程

题目描述: 将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 “LEETCODEISHIRING” 行数为 3 时,排列如下: L C I R E T O E S I I G E D H N 之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“LCIRETOESIIG

leetcode-6: z 字形变换_文丑颜不良啊的博客-爱代码爱编程

题目描述 将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 “PAYPALISHIRING” 行数为 3 时,排列如下: P A H N A P L S I I G Y I R 之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“PAHNAPLS

leetcode 69. x 的平方根-爱代码爱编程

可以使用二分查找法或牛顿迭代法来实现 LeetCode 问题 69. x 的平方根。下面是使用二分查找法和牛顿迭代法的 C++ 实现。 二分查找法 #include <iostream> class Sol

(leetcode学习)110. 平衡二叉树-爱代码爱编程

给定一个二叉树,判断它是否是 平衡二叉树 示例 1: 输入:root = [3,9,20,null,null,15,7] 输出:true 示例 2: 输入:root = [1,2,2,3,3,null,null,4,4] 输出:false 示例 3: 输入:root = [] 输出:

leetcode 17. 电话号码的字母组合-爱代码爱编程

Leetcode 17. 电话号码的字母组合 Leetcode 17. 电话号码的字母组合 一、题目描述二、我的想法三、其他人的题解 一、题目描述 给定一个仅包含数字 2-9 的字符串,返回所有它

golang | leetcode golang题解之第282题给表达式添加运算符-爱代码爱编程

题目: 题解: func addOperators(num string, target int) (ans []string) { n := len(num) var backtrack func(expr []byte, i, res, mul int) backtrack = func(expr []byte, i,

(leetcode学习)236. 二叉树的最近公共祖先-爱代码爱编程

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。” 示例 1: 输入:root = [3,5,1,6,2,0,8,null,n

leetcode707 设计链表-爱代码爱编程

前言 题目: 707. 设计链表 文档: 代码随想录——设计链表 编程语言: C++ 解题状态: 代码功底不够,只能写个大概 思路 主要考察对链表结构的熟悉程度,对链表的增删改查,比较考验代码功底以及对链表的

leetcode:二叉树的中序遍历(c语言)-爱代码爱编程

1、前序遍历:根左右 2、中序遍历:左根右 3、后序遍历:左右根 1、问题概述:二叉树中序遍历 2、示例 示例 1: 输入:root = [1,null,2,3] 输出:[1,3,2] 示例 2: 输入:root = [] 输出:[] 示例 3: 输入:root = [1] 输出:[1

力扣94题(java语言)-爱代码爱编程

题目  思路 使用一个栈来模拟递归的过程,以非递归的方式完成中序遍历(使用栈可以避免递归调用的空间消耗)。 遍历顺序步骤: 遍历左子树访问根节点遍历右子树 package algorithm_leetcode; import java.util.ArrayList; import java.util.List; import java.

leetcode日记(52)最小路径和-爱代码爱编程

怎么最近全是这种题)又是动态规划,和上上题类似。 class Solution { public: int minPathSum(vector<vector<int>>& grid) { int m=grid.size(); int n=grid[0].size();