蓝桥杯 画表格 Java 带字的表格

在图形环境中很容易做出漂亮的表格。但在控制台环境中就比较困难了。

有的时候可以用一些符号大略地模拟:(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);
		}
	}
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值