/* * 画表格 在图形环境中很容易做出漂亮的表格。但在控制台环境中就比较困难了。 有的时候可以用一些符号大略地模拟:(word文档中可能不整齐,拷贝到记事本中看) +-------+------+ |abc |xyz=tt| +-------+------+ |hellomm|t2 | +-------+------+ 本题目要求设计一个程序,把用户输入的内容用这种“准表格”的方式展现出来。具体的要求是: 用户输入的第一行是一个整数,表示接下来有多少行信息。接下来的每行由若干单元组成。单元间用逗号分开。 程序输出:用表格方式重新展现的输入内容。 例如: 用户输入: 3 cat,dog,good-luck 1,2,5 do not use,,that 则程序输出:(word文档中可能不整齐,拷贝到记事本中看) +----------+---+---------+ |cat |dog|good-luck| +----------+---+---------+ |1 |2 |5 | +----------+---+---------+ |do not use| |that | +----------+---+---------+ 从中不难看出: 两个连续的逗号表示中间有一个内容为空的单元 列的数目由最大的单元数的那行决定 列的宽度由同列的最宽的单元决定 单元格中的信息左对齐 可以假设:用户输入的最大行数为30,可能的最多列数为40。 */ import java.util.Scanner; public class 画表格 { // 输出 public static void show(String[][] s,int[] len){ StringBuffer sb = new StringBuffer("+"); for(int i=0;i<len.length;i++){ for(int j=0;j<len[i];j++){ sb.append("-"); } sb.append("+"); } System.out.println(sb); for(String[] x:s){ for(String y:x){ System.out.print(y); } System.out.println("\n"+sb); } } // 拆分串 public static String[][] splitS(String[] s){ String[][] t = new String[s.length][]; for(int i=0;i<s.length;i++){ t[i] = s[i].split(","); // 按分隔符拆分 } return t; } // 取得最长的一个数组长度 public static int maxArrLen(String[] s){ String[][] t = splitS(s); int maxL = 0; for(String[] x:t){ if(x.length>maxL){ maxL = x.length; } } return maxL; } // 得到拆分处理后果的数组 public static String[][] getArr(String[] s,int n){ String[][] ss = new String[n][maxArrLen(s)]; // 拆分串 String[][] t = splitS(s); // 得到临时数组t用来给ss赋值 for(int i=0;i<ss.length;i++){ // 给ss赋值 for(int j=0;j<ss[i].length;j++){ if(j<t[i].length){ ss[i][j] = t[i][j]; // 赋值 }else{ ss[i][j] = ""; // 列数不够,则添空格 } } } return ss; } // 得到每列的最长的串的长度 public static void maxLen(String[][] t, int[] len) { for(int i=0;i<len.length;i++){ for(int j=0;j<t.length;j++){ if(t[j][i].length()>len[i]){ len[i] = t[j][i].length(); // 得到每列的最长的串的长度 } } } } // 填充 "|" 和 " " public static String fillS(String s,int n,int j,int end){ StringBuffer sb = new StringBuffer(); int x = n-s.length(); //sb.insert(0, '|'); sb.append('|'); sb.append(s); for(int i=0;i<x;i++){ sb.append(" "); } if(j==end){ sb.append("|"); } return sb.toString(); } // 补空格和"|"操作 public static void fillSpace(String[][] data,int[] len){ for(int i=0;i<data.length;i++){ for(int j=0;j<data[i].length;j++){ data[i][j] = fillS(data[i][j],len[j],j,data[i].length-1); // 补空格和"|" } } } public static void f(String[] s,int n){ String[][] data = getArr(s,n); // 得到拆分后的所有数据 int[] len = new int[data[0].length]; // 每列最大宽度 maxLen(data, len); // 为len赋值(每列宽度) fillSpace(data,len); // 补空格 加"|" show(data,len); // 输出 } public static void main(String[] args){ Scanner scan = new Scanner(System.in); System.out.println("输入的行数(整数)"); int n = scan.nextInt(); scan.nextLine(); String[] s = new String[n]; for(int i=0;i<n;i++){ s[i] = scan.nextLine(); } f(s,n); } } 运行结果: 输入的行数(整数) 3 hua,biao,ge huabiaoge hua,biaoge +---------+------+--+ |hua |biao |ge| +---------+------+--+ |huabiaoge| | | +---------+------+--+ |hua |biaoge| | +---------+------+--+