版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
Java打印出如图所示的符号沙漏
1、题目描述:
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
2、输入描述:
输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。
3、输出描述:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
4、题目分析:
要打印出如图所示的图案,首先要确定第一行“ * ”的个数,(使用Math.pow((N+1)*1.0/2)),然后根据图中各行空格的数量找到其中的规律再通过循环打出空格。注意最后要计算出剩余的“ * ”数。
5、详细代码:
import java.util.Scanner;
public class Hourglass {
public static void main(String[] args) {
Scanner sr = new Scanner(System.in);
int N = sr.nextInt();
String s =sr.next();
sr.close();
double temp = Math.pow((N+1)*1.0/2, 0.5);
int n = (int) temp;
for(int i=n;i>1;i--) {
for(int j =0;j<n-i;j++) {
System.out.print(" ");
}
for(int k=0;k<2*i-1;k++) {
System.out.print(s);
}
System.out.println();
}
for(int i =1;i<=n;i++) {
for(int j =0;j<n-i;j++) {
System.out.print(" ");
}
for(int k=1;k<=2*i-1;k++) {
System.out.print(s);
}
System.out.println();
}
System.out.println(N-(2*n*n-1));
}
}