java 竖直打印单词_leetcode 1324: 竖直打印单词

import java.util.ArrayList;

import java.util.List;

/**

* @Class PrintVertically

* @Description 1324. 竖直打印单词

* 给你一个字符串 s。请你按照单词在 s 中的出现顺序将它们全部竖直返回。

* 单词应该以字符串列表的形式返回,必要时用空格补位,但输出尾部的空格需要删除(不允许尾随空格)。

* 每个单词只能放在一列上,每一列中也只能有一个单词。

*

* 示例 1:

* 输入:s = "HOW ARE YOU"

* 输出:["HAY","ORO","WEU"]

* 解释:每个单词都应该竖直打印。

* "HAY"

* "ORO"

* "WEU"

*

* 示例 2:

* 输入:s = "TO BE OR NOT TO BE"

* 输出:["TBONTB","OEROOE"," T"]

* 解释:题目允许使用空格补位,但不允许输出末尾出现空格。

* "TBONTB"

* "OEROOE"

* " T"

*

* 示例 3:

* 输入:s = "CONTEST IS COMING"

* 输出:["CIC","OSO","N M","T I","E N","S G","T"]

*

*

* 提示:

* 1 <= s.length <= 200

* s 仅含大写英文字母。

* 题目数据保证两个单词之间只有一个空格。

* @Author

* @Date 2020/6/23

**/

public class PrintVertically {

}

public static List printVertically(String s) {

if (s == null) {

return null;

}

String[] strings = s.split(" ");

int maxlen = 0;

for (int i = 0; i < strings.length; i++) {

maxlen = Math.max(maxlen, strings[i].length());

}

List stringList = new ArrayList<>();

for (int j = 0; j < maxlen; j++) {

// 保存竖直排列后的一行

StringBuilder temp = new StringBuilder("");

// blankTemp保存每行大写字符之间的空格,最后一个大写字符后的空格串直接丢弃

StringBuilder blankTemp = new StringBuilder("");

for (int i = 0; i < strings.length; i++) {

if (j >= strings[i].length()) {

blankTemp.append(" ");

} else {

temp.append(blankTemp);

blankTemp = new StringBuilder("");

temp.append(strings[i].charAt(j));

}

}

stringList.add(temp.toString());

}

return stringList;

}

// 测试用例

public static void main(String[] args) {

String s = "HOW ARE YOU";

List ans = printVertically(s);

System.out.print("demo01 result:[");

for (int i = 0; i < ans.size(); i++) {

System.out.print("," + ans.get(i));

}

System.out.println("]");

s = "TO BE OR NOT TO BE";

ans = printVertically(s);

System.out.print("demo02 result:[");

for (int i = 0; i < ans.size(); i++) {

System.out.print("," + ans.get(i));

}

System.out.println("]");

s = "CONTEST IS COMING";

ans = printVertically(s);

System.out.print("demo03 result:[");

for (int i = 0; i < ans.size(); i++) {

System.out.print("," + ans.get(i));

}

System.out.println("]");

}

KMP算法是一种字符串匹配算法,用于在一个文本串S内查找一个模式串P的出现位置。它的时间复杂度为O(n+m),其中n为文本串的长度,m为模式串的长度。 KMP算法的核心思想是利用已知信息来避免不必要的字符比较。具体来说,它维护一个next数组,其中next[i]表示当第i个字符匹配失败时,下一次匹配应该从模式串的第next[i]个字符开始。 我们可以通过一个简单的例子来理解KMP算法的思想。假设文本串为S="ababababca",模式串为P="abababca",我们想要在S中查找P的出现位置。 首先,我们可以将P的每个前缀和后缀进行比较,得到next数组: | i | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | --- | - | - | - | - | - | - | - | - | | P | a | b | a | b | a | b | c | a | | next| 0 | 0 | 1 | 2 | 3 | 4 | 0 | 1 | 接下来,我们从S的第一个字符开始匹配P。当S的第七个字符和P的第七个字符匹配失败时,我们可以利用next[6]=4,将P向右移动4个字符,使得P的第五个字符与S的第七个字符对齐。此时,我们可以发现P的前五个字符和S的前五个字符已经匹配成功了。因此,我们可以继续从S的第六个字符开始匹配P。 当S的第十个字符和P的第八个字符匹配失败时,我们可以利用next[7]=1,将P向右移动一个字符,使得P的第一个字符和S的第十个字符对齐。此时,我们可以发现P的前一个字符和S的第十个字符已经匹配成功了。因此,我们可以继续从S的第十一个字符开始匹配P。 最终,我们可以发现P出现在S的第二个位置。 下面是KMP算法的C++代码实现:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值