题目
题目链接:https://leetcode-cn.com/problems/print-words-vertically/
这题目很好理解就直接上代码了
代码
class Solution {
public List<String> printVertically(String s) {
//创建list集合来存放答案
List<String> list = new ArrayList<String>();
//将字符串切割
String[] s1 = s.split(" ");
//创建长度用来比较
int length = Integer.MIN_VALUE;
//遍历长度来获取最大字符串长度
for (String string : s1) {
if(string.length()>length) {
length = string.length();
}
}
//遍历字符串数组
for (int i = 0; i < length; i++) {
//获取StringBuffer对象来进行字符串截切
StringBuffer sb = new StringBuffer();
for(String str : s1) {
//如果索要字符的位置超出字符串就用空格代替
if(i>=str.length()) {
sb.append(" ");
}else {//如果没有就将字符放入字符串对象中
char a = str.charAt(i);
sb.append(str.charAt(i));
}
}
//将末尾的空格处理
for(int j=sb.length()-1;j>=0;j--) {
if(sb.charAt(j)==' ') {
sb.deleteCharAt(j);
}else {
break;
}
}
//将答案放入集合中
list.add(sb.toString());
//System.out.println(sb.toString());
}
return list;
}
}