在图形环境中很容易做出漂亮的表格。但在控制台环境中就比较困难了。
有的时候可以用一些符号大略地模拟:(word文档中可能不整齐,拷贝到记事本中看)
+-------+------+
|abc |xyz=tt|
+-------+------+
|hellomm|t2 |
+-------+------+
本题目要求设计一个程序,把用户输入的内容用这种“准表格”的方式展现出来。具体的要求是:
用户输入的第一行是一个整数,表示接下来有多少行信息。接下来的每行由若干单元组成。单元间用逗号分开。
程序输出:用表格方式重新展现的输入内容。
例如:
用户输入:
3
cat,dog,good-luck
1,2,5
do not use,,that
则程序输出:(word文档中可能不整齐,拷贝到记事本中看)
从中不难看出:
两个连续的逗号表示中间有一个内容为空的单元
列的数目由最大的单元数的那行决定
列的宽度由同列的最宽的单元决定
单元格中的信息左对齐
一个渣渣的程序,欢迎指正。。。
import java.util.Scanner;
import java.util.Vector;
public class 画表格 {
//用于记录所有词,相当于一个二维集合
static Vector<Vector<String>> all=new Vector<Vector<String>>();
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
int n=Integer.parseInt(sc.nextLine());
//将输入的每一行变成集合放入all集合中
for(int i=0;i<n;i++){
Vector<String> per=new Vector<String>();
String s=sc.nextLine();
String[] ss=s.split(",");
for(int j=0;j<ss.length;j++){
//去掉字符串中的前后空格并加入
per.add(ss[j].trim());
}
all.add(per);
}
sc.close();
start(n);
}
public static void start(int n){
int n1=0;
//取输入行的长度最长的一行作为数组的长度
for(int i=0;i<all.size();i++){//用于打印-号和空格
if(all.elementAt(i).size()>n1){
n1=all.elementAt(i).size();
}
}
//用于存储每列最大的长度
int[] max=new int[n1];
//找到最大的长度。
for(int i=0;i<max.length;i++){
Vector<String> per=new Vector<String>();
for(int j=0;j<all.size();j++){
per=all.elementAt(j);
//获取每一列的最大长度
if(i<per.size()){
if(max[i]<per.elementAt(i).length()){
max[i]=per.elementAt(i).length();
}
}
}
//System.out.println(max[i]);
}
//生成行的边
String line="+";
for(int i=0;i<max.length;i++){
for(int j=0;j<max[i];j++){
line+="-";
}
line+="+";
}
System.out.println(line);
//开始打印表格,每次打印一行
for(int m=0;m<all.size();m++){
//用于存放每一列的元素
String[] s=new String[max.length];
for(int i=0;i<s.length;i++){
s[i]="|";//把表格的第一个字符设为“|”
}
Vector<String> vc=new Vector<String>();
//用vc遍历all集合中的每一个元素
vc=all.elementAt(m);
for(int i=0;i<max.length;i++){
//将每一列的单词加入对应的s中
if(i<vc.size()){//用于解决输入每行可能长度不同
s[i]+=vc.elementAt(i);
}
if(s[i].length()<max[i]+1){
int temp=(max[i]+1-s[i].length());
//添加空格使s[i]得长度跟max[i]+1一样长(1为添加的“|”)
for(int k=0;k<temp;k++){
s[i]+=" ";
}
}
}
//对最后一个元素加“|”
s[s.length-1]+="|";
//遍历打印s
for(int i=0;i<s.length;i++){
System.out.print(s[i]);
}
System.out.println();
System.out.println(line);
}
}
}