天天看点

PTA乙级1027

1027

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个

“*”

,要求按下列格式打印

* * * * *

 

* * *

  

*

 

* * *

* * * * *

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。

##### 输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

*****

***

*

***

*****

2

我的思路是先判断给的数是偶数还是奇数,然后根据偶数的一半或奇数减一的一半得出第一行的字符数,用for循环输出空格和给出的符号但是还是有一些逻辑问题,后来转换了下思路先得出一个沙漏最多可装入的字符数的规律,然后根据此规律得出第一行最大符号数量,然后用循环先输出空格在输出符号。

package test1;

import java.util.Scanner;

public class PTA1027 {
    public static void main(String[] args){
        Scanner in=new Scanner(System.in);
        int N=in.nextInt();
        char c=in.next().charAt(0);
        in.close();
        int m=1;
        int t=1;
        //沙漏能存放的符号数
        while (m<=N) {
            m += 2 * (2 * t + 1);
            t++;
        }
        int dy=N-(m-2*(2*(t-1)+1));//剩余符号
        int k=2*(t-2)+1;
        int l=t-2;
        int d=4;
        for(int i=1;i<=l+1;i++){//沙漏上面一半符号
            for (int j=1;j<i;j++){
                System.out.print(" ");
            }
            for (int x=k;x>0;x--){
                System.out.print(c);

            }
            k=k-2;
            System.out.println();
        }
        int s=l;
        for(int i=1;i<=l;i++){//沙漏下面一半少一行只有一个符号的符号
            for (int j=s;j>1;j--){
                System.out.print(" ");
            }s=s-1;
            for (int x=1;x<d;x++){
                System.out.print(c);
            }
            d=d+2;

            System.out.println();
        }
        System.out.println(dy);
    }
}