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