天天看點

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);
    }
}