本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個「*」,要求按下列格式列印
***
****
****
****
**
所謂「沙漏形狀」,是指每行輸出奇數個符號;各行符號中心對齊;相鄰兩行符號數差2;符號數先從大到小順序遞減到1,再從小到大順序遞增;首尾符號數相等。
給定任意n個符號,不一定能正好組成乙個沙漏。要求列印出的沙漏能用掉盡可能多的符號。
輸入格式:
輸入在一行給出1個正整數n(≤1000)和乙個符號,中間以空格分隔。
輸出格式:
首先列印出由給定符號組成的最大的沙漏形狀,最後在一行中輸出剩下沒用掉的符號數。
輸入樣例:
19
*
輸出樣例:
***
****
****
****
**2
題目分析:
首先找到沙漏形狀字元個數的規律:n^2-1
然後考慮該如何找到這個n,利用迴圈讓n逐漸增大知道(n+1)^2-1 > 輸入的數字才停止
然後再考慮怎麼輸出沙漏:1.將沙漏分為上下兩部分進行列印。2.兩部分都是先打空格再打字元
**如下:
#include
using
namespace std;
int n, row, i;
char c;
intmain()
row--
;int temp = row;
for(i=
0; i) temp =2;
for(i=
0; i1; i++
) cout << n-
(row*row*2-
1);return0;
}
嗶哩嗶哩/bilibili:羊卓的楊 L1 002 列印沙漏 (20 分)
l1 002 列印沙漏 20 分 本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個 要求按下列格式列印 所謂 沙漏形狀 是指每行輸出奇數個符號 各行符號中心對齊 相鄰兩行符號數差2 符號數先從大到小順序遞減到1,再從小到大順序遞增 首尾符號數相等。給定任意n個符號,不一定能正好組成乙個...
L1 002 列印沙漏 (20 分
l1 002 列印沙漏 20 分 本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個 要求按下列格式列印 所謂 沙漏形狀 是指每行輸出奇數個符號 各行符號中心對齊 相鄰兩行符號數差2 符號數先從大到小順序遞減到1,再從小到大順序遞增 首尾符號數相等。給定任意n個符號,不一定能正好組成乙個...
L1 002 列印沙漏 (20 分
l1 002 列印沙漏 20 分 本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個 所謂 沙漏形狀 是指每行輸出奇數個符號 各行符號中心對齊 相鄰兩行符號數差2 符號數先從大到小順序遞減到1,再從小到大順序遞增 首尾符號數相等。給定任意n個符號,不一定能正好組成乙個沙漏。要求列印出的沙...