PAT乙级真题沙漏

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_41291067/article/details/101699718

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

6、运行结果

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_41291067/article/details/101699718