思路:
1、先计算打印出上三角所需的行数k:由k可以推出沙漏字符总数为{[(1+2k-1)*k]/2}*2-1=2*k*k-1
2、打印上三角:由行数i可以推出每行空格数为i(从0开始),字符数2*(k-i)-1
3、打印下三角:每行空格数=(最后一行字符数-当前行字符数)/2,即[(2*k-1)-(2*i+1)]/2=k-i-1;
每行字符数=2*i+1
代码:
#include<iostream>
using namespace std;
int main() {
int n;
char c;
cin >> n >> c;
int k = 0;
while (2 * k*k - 1 <= n)
k++;
k -= 1;
for (int i = 0; i < k; i++) {
for (int j = 0; j < i; j++)
cout << " ";
for (int j = i; j < i + 2 * (k - i)- 1; j++) {
if (j == i + 2 * (k - i) - 2)
cout << c << endl;
else
cout << c;
}
}
for (int i = 1; i < k; i++) {
for (int j = 0; j < k - i - 1; j++)
cout << " ";
for (int j = k - i - 1; j <( k - i -1 )+2 * i + 1; j++) {
if (j == (k - i - 1)+2 * i)
cout << c << endl;
else
cout << c;
}
}
system("pause");
return 0;
}