思路来源:https://blog.youkuaiyun.com/wenyunick/article/details/104589981
感谢大哥
2.将给定字符和行数按照W排列,再按行输出
例:输入:abcde,3
a e
b d
c
输出:“aebdc”
思路:
1.当n = 1时,直接出字符串即可。
2.当n = 2时,只需要先输出单数,再输出双数即可。
3.当n > 2时,可以用二维字符组的方法来实现;将字符串用 str.charAt(i)的方法依次输入到字符组中,字符组的列数一直增加,但行数由 递增 到 递减 再回到递增,不断循环。
以题中n = 3 为例,行数变化的规律:从0->2;2->0。
package com.bjsxt;
import java.util.*;
import com.sun.org.apache.xpath.internal.objects.XString;
public class Main {
public static void main(String[] args) {
String str = "abcde"; //这里输入字符串
int length = str.length();
int x = 1;
int n=3; //这里改变行数
boolean fla = true;
char[][] arr = new char[n][length];
arr[0][0] = str.charAt(0);
for (int j = 1; j < length; j++) //列数依次加1
{
for (int i = x; i < n; i++) //控制行数
{
if (i != (n - 1) && fla == true) //如果不是最后一行,还处于下降状态
{
arr[i][j] = str.charAt(j);
x = i + 1;
break;
} else if (i != (n - 1) && fla == false) //如果不是最后一行,在上升状态
{
arr[i][j] = str.charAt(j);
x = i - 1;
if (x == 0) //如果上升后到达最初一行,变为下降状态
{
fla = !fla;
}
break;
} else //如果到达最后一行
{
fla = !fla;
arr[i][j] = str.charAt(j);
x = i - 1;
break;
}
}
}
for(int i=0; i < 3; i++) //打印结果,按照先打印上面一行,再打印下面一行的顺序
{
for(int j = 0; j < length; j++)
{
if(arr[i][j] != '\0') //如果字符串为空,就不打印
System.out.print(arr[i][j]);
}
}
}
}
当输入“abcde”和3时,结果为:aebdc