美文网首页
2015年Java方向C组第五题

2015年Java方向C组第五题

作者: D丝学编程 | 来源:发表于2021-02-12 11:33 被阅读0次

标题:格子中输出

stringInGrid方法会在一个指定大小的格子中打印指定的字符串。

要求字符串在水平、垂直两个方向上都居中。

如果字符串太长,就截断。

如果不能恰好居中,可以稍稍偏左或者偏上一点。

下面的程序实现这个逻辑,请填写划线部分缺少的代码。

public static void stringInGrid(int width, int height, String s)
{
    if(s.length()>width-2) s = s.substring(0,width-2);
    System.out.print("+");
    for(int i=0;i<width-2;i++) System.out.print("-");
    System.out.println("+");

    for(int k=1; k<(height-1)/2;k++){
        System.out.print("|");
        for(int i=0;i<width-2;i++) System.out.print(" ");
        System.out.println("|");
    }

    System.out.print("|");

    String ff = _______________________________________________________;  //填空
    System.out.print(String.format(ff,"",s,""));

    System.out.println("|");

    for(int k=(height-1)/2+1; k<height-1; k++){
        System.out.print("|");
        for(int i=0;i<width-2;i++) System.out.print(" ");
        System.out.println("|");
    }   

    System.out.print("+");
    for(int i=0;i<width-2;i++) System.out.print("-");
    System.out.println("+");    
}

对于题目中数据,应该输出:

+------------------+
|                  |
|     abcd1234     |
|                  |
|                  |
+------------------+

解析:本体代码长,但是逻辑相对简单,注释如下:

public static void stringInGrid(int width, int height, String s)
{
    
    if(s.length()>width-2) s = s.substring(0,width-2);
    System.out.print("+");
    for(int i=0;i<width-2;i++) System.out.print("-");
    System.out.println("+");

    for(int k=1; k<(height-1)/2;k++){
        System.out.print("|");
        for(int i=0;i<width-2;i++) System.out.print(" ");
        System.out.println("|");
    }

    System.out.print("|");

    String ff = _______________________________________________________;  //填空
    System.out.print(String.format(ff,"",s,""));

    System.out.println("|");

    for(int k=(height-1)/2+1; k<height-1; k++){
        System.out.print("|");
        for(int i=0;i<width-2;i++) System.out.print(" ");
        System.out.println("|");
    }   

    System.out.print("+");
    for(int i=0;i<width-2;i++) System.out.print("-");
    System.out.println("+");    
}

public static void main(String[] args) 
{
    stringInGrid(20,6,"abcd1234");
}

如下代码:

String.format(ff,"",s,"")

表示控制ff字符串有三个参数,分别为:"",s,""。

如果填写:String ff = "%s%s%s";,打印结果为:

+------------------+
|                  |
|abcd1234|
|                  |
|                  |
+------------------+

a前面没有空格,4后面也没有空格,则我们需要计算空格数量,把空格添加上去,所以答案为:

String ff = "%"+((width-2-s.length())/2)+"s%s%"+(width-2-s.length()-((width-2-s.length())/2))+"s";  //填空

左边空格数量=总长度减去两边竖线的长度2,在减去字符串长度,将结果除以2(题目提示,如果不能居中,则靠左,靠上显示,所以结果不需要进行+1操作);

右边空格数量=总长度减去两边竖线的长度2,在减去字符串长度,然后减去左边的空格长度;

相关文章

  • 2015年Java方向C组第五题

    标题:格子中输出 stringInGrid方法会在一个指定大小的格子中打印指定的字符串。 要求字符串在水平、垂直两...

  • 2016年Java方向C组第五题

    分小组 9名运动员参加比赛,需要分3组进行预赛。有哪些分组的方案呢? 我们标记运动员为 A,B,C,... I下面...

  • 2018年Java方向C组第五题

    标题:书号验证 2004年起,国际ISBN中心出版了《13位国际标准书号指南》。原有10位书号前加978作为商品分...

  • 2017年Java方向C组第五题

    标题: 杨辉三角 杨辉三角也叫帕斯卡三角,在很多数量关系中可以看到,十分重要。 两边的元素都是1, 中间的元素是左...

  • 9、正则表达式

    注:第0组(d(a(b))(c))第1组 d(a(b))(c)第2组 a(b)第3组 b 一、正则表达式的概述和简...

  • 浅谈学好java需要熟练掌握的知识

    个人是从C++方向转到JAVA方向的新手,个人认为学号JAVA需要从以下方面入手,学好下面那些知识,JAVA基本可...

  • 2014年Java方向C组第八题

    标题:兰顿蚂蚁 兰顿蚂蚁,是于1986年,由克里斯·兰顿提出来的,属于细胞自动机的一种。 平面上的正方形格子被填上...

  • 2014年Java方向C组第九题

    标题:地宫取宝 X 国王有一个地宫宝库。是 n x m 个格子的矩阵。每个格子放一件宝贝。每个宝贝贴着价值标签。 ...

  • 2015年Java方向C组第二题

    第二题 标题:立方尾不变 有些数字的立方的末尾正好是该数字本身。比如:1,4,5,6,9,24,25,.... 请...

  • 2015年Java方向C组第三题

    第三题 标题:无穷分数 无穷的分数,有时会趋向于固定的数字。 请计算【图1.jpg】所示的无穷分数,要求四舍五入,...

网友评论

      本文标题:2015年Java方向C组第五题

      本文链接:https://www.haomeiwen.com/subject/wbzlxltx.html