字符串 Z 字形变换(Java)
将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。
比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:
L C I R
E T O E S I I G
E D H N
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。
示例 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
package com.loo;
import java.util.ArrayList;
import java.util.List;
public class ZString {
public static void main(String[] args) {
String str = "LEETCODEISHIRING";
int rows1 = 3,rows2 = 4;
System.out.println(zString1(str , rows1));
System.out.println(zString1(str , rows2));
System.out.println(zString2(str , rows1));
System.out.println(zString2(str , rows2));
}
/*
使用 min(numRows,len(s)) 个列表来表示 Z 字形图案中的非空行。
从左到右迭代 str ,将每个字符添加到合适的行。可以使用当前行和当前方向这两个变量对合适的行进行跟踪。向上移动到最上面的行或向下移动到最下面的行时,当前方向才会发生改变。
时间复杂度:O(n)O(n)O(n),其中 n==len(s)
空间复杂度:O(n)。
*/
public static String zString1(String str , int rows) {
if (str == null || rows <= 1 || str.length() == 1) {
return str;
}
List<StringBuilder> listRows = new ArrayList<StringBuilder>();
for (int i=0;i<Math.min(rows, str.length());i++) {
listRows.add(new StringBuilder());
}
int currentRow = 0;
boolean down = false;
for (char c:str.toCharArray()) {
listRows.get(currentRow).append(c);
if (currentRow>=rows-1 || currentRow<=0) {
down = !down;
}
currentRow += down ? 1 : -1;
}
StringBuilder result = new StringBuilder();
for (StringBuilder r : listRows) {
result.append(r);
}
return result.toString();
}
/*
首先访问 第 0 行中的所有字符,接着访问 第 1 行,然后 第 2 行,依此类推...
时间复杂度:O(n),其中 n==len(s)。每个索引被访问一次。
空间复杂度:O(n)。
*/
public static String zString2(String str , int rows) {
if (str == null || rows <= 1 || str.length() == 1) {
return str;
}
int len = str.length();
StringBuilder result = new StringBuilder();
int step = 2 * rows - 2;
for (int i=0;i<rows;i++) {
for (int j=0;j+i<len;j+=step) {
result.append(str.charAt(j+i));
if (i!=0&&i!=rows-1&&j+step-i<len) {
result.append(str.charAt(j+step-i));
}
}
}
return result.toString();
}
}
字符串 Z 字形变换(Java)相关推荐
- Z 字形变换 C++实现 java实现 leetcode系列(六)
Z 字形变换 java实现 C++实现 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 ...
- Java算法题:Z字形变换
Java算法题:Z字形变换 将一个给定字符串 s 根据给定的行数 numRows ,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "PAYPALISHIRING" 行 ...
- java编写字母z算法_【Java】【每日算法/刷穿 LeetCode】6. Z 字形变换(中等)
首页 专栏 java 文章详情 0 [每日算法/刷穿 LeetCode]6. Z 字形变换(中等) 宫水三叶发布于 今天 12:03 题目描述 将一个给定字符串 s 根据给定的行数 numRows , ...
- java z+_Java Z 字形变换
– 题目:Z 字形变换 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: ...
- [模拟|字符串] leetcode 6 Z字形变换
[模拟|字符串] leetcode 6 Z字形变换 1.题目 题目链接 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHI ...
- Java Z 字形变换
- 题目:Z 字形变换 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: ...
- Z字形变换(Java)
今天做到了一道还是非常有意思的题,中间有很多过程,对我的启发还是很大的,因此就把它总结出来分享一下,以让自己能够对这次经历更加深刻.下面的题估计很多Lee迷们都有做到过. 一.题目 将一个给定字符串 ...
- Java实现 LeetCode 6 Z字形变换
6. Z 字形变换 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: L ...
- LeetCode Algorithm 6. Z 字形变换
6. Z 字形变换 Ideas 这题的思路其实只要想到了就很简单,首先创建一个numRows行的矩阵,每一行用来存Z字变换后每一行的字符,然后遍历字符串s,其实就是从上往下然后从下往上填充到每一行,所 ...
最新文章
- 推荐10个windows软件,让你的办公更高效
- Google跨平台UI框架 Flutter beta 重磅发布,这里有你需要了解的一切
- 得到win7 win8的桌面句柄
- 两个构件的重合点_初三物理易错点:你被眼睛欺骗了,那些『平面镜成像』中的困惑...
- java 中怎么加汉字,jquery怎么向body里面增加文字
- 数据结构之并查集:路径压缩继续优化并查集——20
- java ee是什么_死磕 java集合之HashSet源码分析
- 使用IPFS集群搭建创建私有IPFS网络
- Magento 获取系统设置 How to get data from Magento System Configuration
- 步进电机可以连续运转吗?
- 【matlab】解决每次打开.m文件都会弹出新窗口
- 计算机-flash遮罩层动画,flash遮罩层动画作业
- Python字符串:isspace、istitle、isupper、islower
- 2023华南农业大学计算机考研信息汇总
- zencart模板如何设计
- 快播将关闭QVOD服务器 清理低俗内容与涉盗版内容
- 根据三个点的坐标计算三角形面积
- Python采集网易云音乐
- 8位算术逻辑运算实验
- 腾讯云企业邮箱设置别名