美文网首页
26.蓝桥杯2013第八题打印十字图

26.蓝桥杯2013第八题打印十字图

作者: FiveZM | 来源:发表于2018-03-31 12:41 被阅读0次
p1.JPG

小明为某机构设计了一个十字型的徽标(并非红十字会啊),如上所示
为了能准确比对空白的数量,程序要求对行中的空白以句点(.)代替。

输入格式:
一个正整数 n (n<30) 表示要求打印图形的层数

输出:
对应包围层数的该标志。

思路:
将图形分为4部分,每部分都是独立的一个for循环来赋值

package 第四届;

import java.util.Scanner;

public class A8_mine {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(); //3
        int length = 4*n+5;   //17
        String[][] s = new String[length][length];
        for(int i = 0;i<length;i++) {
            for(int j = 0;j<length;j++) {
                s[i][j] = ".";
            }
        }
        int mid = length/2;
        //打印中间的十字
        s[mid][mid] = s[mid-1][mid] = s[mid-2][mid] = s[mid+1][mid] = s[mid+2][mid] = "$";
        s[mid][mid-1] = s[mid][mid-2] = s[mid][mid+1] = s[mid][mid+2] = "$";
        
        //n为层数,打印多少层外围
        for(int i = 0;i<n;i++) {//控制循环行数
            /**     1.由图中我们可以看出,第0行"$"有13个,在第2行"$"有9个,第4行"$"有5个,从规律中可以知道没隔i*2行少4个"$",
             *      所以在for循环中控制没行打印的个数,判断条件为 j<length-i*4,又因为在第0行开始,就已经少了4个字符,所以在一开始的判断中就要减去4
             *      所以是j<length-i*4-4
             * 
..$$$$$$$$$$$$$..
.................
....$$$$$$$$$....
.................
......$$$$$......
.................
........$........
........$........
......$$$$$......
........$........
........$........
.................
......$$$$$......
.................
....$$$$$$$$$....
.................
..$$$$$$$$$$$$$..
             */
            for(int j =0;j<length-i*4-4;j++) {//控制列数,每行都少4个$,因为是隔行少4个,所以是每隔i*2行
                s[0+i*2][j+2+i*2] = "$";        //打印上行
                s[length-1-i*2][j+2+i*2] = "$"; //2.打印下行,打印从下往上,用的是减号,并且是每隔两行才存入"$",所以[length-1-i*2]
                                                //打印元素,因为是从左往右,所以是加号,本来列应该是[j]开始的,因为初始就是从2开始,所以[j+2]开始,
                                                //又因为每两层就往缩小2个字符,所以[j+2+i*2]
            }
            /**     2.做这种题,我们要先做出固定的第一个,再将隔多少行变化的条件加上去,
             *      例如这个循环的关键是在于列的变化,所以我们就抓住列 
             *      我们第0列打印"$"的是在s[2][0]
             *              第2列打印"$"的是在s[4][2]
             *              第4列打印"$"的是在s[6][4]
             *         从这可以看出,在行中,i代表层数,从最外层开始代表0层,每隔i*2行开始打印"$",而第一次打印是第2行,所以初始化要加i*2+2,i*2+2+j是随着j角标移动行
             * 而列中开始打印"$"和所代表的列数角标一致,第0列就从0开始打印,
             *          第2列则从2开始,所以规律为 i*2, 第0层 ,0 *2 = 0,所以从0角标开始打印
             *          搞定了+号左边的打印,那么+号右边的打印也同理,只是开始角标为length-1,再就是从右往左打印,所以要减少,又是隔列打印,所以length-1 - i*2
012345678
................. 0
................. 1
$...............$ 2
$...............$ 3
$.$...........$.$ 4
$.$...........$.$ 5
$.$.$...$...$.$.$ 6
$.$.$...$...$.$.$ 7
$.$.$.$$$$$.$.$.$ 8
$.$.$...$...$.$.$ 9
$.$.$...$...$.$.$ 10
$.$...........$.$ 11
$.$...........$.$ 12
$...............$ 13
$...............$ 14
................. 15
................. 16
             */
            for(int j = 0;j<length-i*4-4;j++) {
                s[i*2+2+j][i*2] = "$";
                s[i*2+2+j][length-1-i*2] = "$";
            }
            /**3.
             * 
.................
.................
$$$...........$$$
.................
..$$$.......$$$..
.................
....$$$.$.$$$....
........$........
......$$$$$......
........$........
....$$$.$.$$$....
.................
..$$$.......$$$..
.................
$$$...........$$$
.................
.................
 
             */
            for(int j=0;j<3;j++) {
                s[i*2+2][j+i*2] = "$";//十字走上角
                s[i*2+2][length-1-i*2-j] = "$";//十字右上角
                s[length-3-i*2][j+i*2] = "$";//十字左下角
                s[length-3-i*2][length-1-i*2-j] = "$";//十字右下角
            }
            /**4.空缺的那个位置
             * 
.................
..$...........$..
.................
....$.......$....
.................
......$...$......
........$........
........$........
......$$$$$......
........$........
........$........
......$...$......
.................
....$.......$....
.................
..$...........$..
.................
             */
            s[i*2+1][i*2+2] = "$";
            s[i*2+1][length-i*2-3] = "$";
            s[length-i*2-2][i*2+2] = "$";
            s[length-i*2-2][length-i*2-3] = "$";
        }
        
        
        
        
        
        //打印
        for(int i = 0;i<length;i++) {
            for(int j = 0;j<length;j++) {
                System.out.print(s[i][j]);
            }
            System.out.println();
        }
    }

}

相关文章

  • 26.蓝桥杯2013第八题打印十字图

    小明为某机构设计了一个十字型的徽标(并非红十字会啊),如上所示为了能准确比对空白的数量,程序要求对行中的空白以句点...

  • 蓝桥杯 历届试题 打印十字图

    问题描述小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:..$$$$$$$$$$$$$....$....

  • 蓝桥杯_ 历届试题 打印十字图

    思路:这个题目比较简单,一开始没看出来是什么图形,后来突然发现,中间是一个十字架,周围是一个闭合的图形把中间的十字...

  • 蓝桥杯 打印十字圈

    以上就是题目 根据那个坑爹提示,曾以为还要计算很多公式只要把题解出来就可以嘛(也许推出公式之类的更快一些吧...)...

  • 蓝桥杯真题题解收藏

    收藏一些在网上发现的,觉得写的不错的蓝桥杯真题题解内容,给学生练习备战蓝桥杯时所用。2020蓝桥杯省赛第二场C组_...

  • [蓝桥杯]正则问题

    问题 1887: [蓝桥杯][2017年第八届真题]正则问题 题目描述 考虑一种简单的正则表达式:只由 x ( )...

  • 包子凑数

    第八届蓝桥杯省赛Java B组第八题 小明几乎每天早晨都会在一家包子铺吃早餐。他发现这家包子铺有N种蒸笼,其中第i...

  • 【蓝桥杯python】小白的艰难刷题之路。A+B问题

    先给大家献上蓝桥杯的练习系统,因为我是新手刷题人所以先更新一下基础练习的普通试题集。“蓝桥杯”练习系统 (lanq...

  • 打印字符图形(蓝桥杯基础题 Java版)

    问题描述利用字母可以组成一些美丽的图形,下面给出了一个例子:ABCDEFGBABCDEFCBABCDEDCBABC...

  • 蓝桥杯算法题练习

    1.入门训练 Fibonacci数列 最基础的,用java,普通无脑递归必爆。 2.入门训练 圆的面积 注意输出的...

网友评论

      本文标题:26.蓝桥杯2013第八题打印十字图

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