1027 打印沙漏 (20 分)——for循环
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2
public class Main {
static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
public static void main(String[] args) throws IOException {
String[] tmp = in.readLine().split(" ");
int n = Integer.valueOf(tmp[0]);
String c = tmp[1];
int sum = 1;
int x = 1;
while ((sum + 2 * (x + 2)) <= n) {
x += 2;
sum += x * 2;
}
int kk = 0;
for (int i = x; i >= 1; i = i - 2) {
for (int m = 0; m < kk; m++) {
System.out.print(" ");
}
kk++;
for (int j = 0; j < i; j++) {
System.out.print(c);
}
System.out.println();
}
kk=kk-2;
for (int i = 3; i <= x; i = i + 2) {
kk--;
for (int m = kk; m >= 0; m--) {
System.out.print(" ");
}
for (int j = 0; j < i; j++) {
System.out.print(c);
}
System.out.println();
}
System.out.println(n-sum);
}
}