java:利用数组实现将古诗词纵向输出

时间:2023-03-09 05:05:36
java:利用数组实现将古诗词纵向输出
 

java:利用二维数组实现将古诗词纵向输出.

从网络上随便搜索一首古诗词,这里刻意选择句子长短不一的诗词

1.首先先把诗词放进一个二维数组中.

这里将数组类型定义成char 类型,因为将其定义为String [][]poem的话输入句子时候表达形式就要这样写:

这种方式显然非常的麻烦.

String poem[][]=String [][]poem{
{"维","天","之","命",","},
{"於","穆","不","已"},
……
};

于是可以通过toCharArray()这个函数把字符串转换为字符数组.

  1 public class poem {
2 public static void main(String[] args) {
3 char [][]poem=new char[][]{
4 "维天之命,".toCharArray(),
5 "於穆不已。".toCharArray(),
6 "於乎不显,".toCharArray(),
7 "文王之德之纯.".toCharArray(),
8 "假以溢我,".toCharArray(),
9 "我其收之。".toCharArray(),
10 "骏惠我文王,".toCharArray(),
11 "曾孙笃之。".toCharArray()
12 };
2.接下来就是思考怎么去排列的问题了,一共要循环多少次? 
这里我们知道对于词语,字数每一行并不固定,要找出最大的字数长度,也就是说循环的次数就是我们最大的字数长度.保证每一行每一个元素都被访问到.
    int max = 0;                // 获取最大的字数长度
for (int i = 0; i < poem.length+1; i++) {
int t = poem[i].length; // 获取第i行的长度
if (t > max){ // 第i行的长度大于最大值
max = t;
}
}
3.通过for循环,来把数组重新排列.
         for (int i=0;i<max;i++){                  //这里代表输出多少行
for (int j=arrays.length-1;j>=0;j--){
// j代表的是排列前数组的行,用来判断原来第j行的字数 if (i<arrays[j].length){
System.out.print(arrays[j][i]);
}else{
System.out.print(" ");
}
}
System.out.println();
}
}
}

运行之后,这里都意识到一个问题,这里的词每一行的字数都不一样,原来是有8行7列,而竖着输出则会有7行8列.
显然会有一个提示出现:
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8
at zhengli.daysixarr.main(daysixarr.java:27)

原来的27行代码稍稍修改为28行代码,就运行正常了.

原因是因为超出了数组的空间界限,

将数组原来的长度加上1,这样子就把原来的7行8列,'扩展'成8行8列.

27        // int t = poem[i].length;         // 获取第i行的长度
28 int t = poem[i].length+1;

运行结果:

曾骏我假文於於维
孙惠其以王乎穆天
笃我收溢之不不之
之文之我德显已命
。王。,之,。,
 ,  纯   
    .