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