您的位置:首页 > 其它

LeetCode OJ ZigZag Conversion

2016-05-11 16:47 393 查看
题目描述:

给定一个字符串和一个行数,数据分布的方式是ZigZag分布,ZigZag的意思是锯齿分布

分析:

看到这道题的时候,我首先不理解ZigZag是啥意思,英语so poor,查了字典后,才知道是锯齿的意思。

知道锯齿就有趣多了

在这里我们用到的是StringBuffer,定义一个StringBuffer数组,根据行数设定StringBuffer的大小

每个StringBuff
import java.util.Scanner;

public class ZigZag{
public String convert(String s, int numRows){
if(numRows < 2){
return s;
}
StringBuffer[] sb = new StringBuffer[numRows];
int index = 0, incre = 1;
for(int i = 0;i<sb.length;i++){
sb[i] = new StringBuffer(" ");
}
for(int i=0;i<s.length();i++){
sb[index].append(s.charAt(i));
if(index == 0){incre = 1;}
if(index == numRows-1){incre = -1;}
index += incre;
}
String re = "";
for(int i=0;i<sb.length;i++){
re+=sb[i];
}
return re;

}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.next();
System.out.println(new ZigZag().convert(str,4));
}
}


er存储对应的那一行,最后把这些行都凑到一起就ok了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: