牛客网_PAT乙级_1017打印沙漏(20)
生活随笔
收集整理的這篇文章主要介紹了
牛客网_PAT乙级_1017打印沙漏(20)
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目描述
本題要求你寫個(gè)程序把給定的符號(hào)打印成沙漏的形狀。例如給定17個(gè)“*”,要求按下列格式打印
*****************所謂“沙漏形狀”,是指每行輸出奇數(shù)個(gè)符號(hào);各行符號(hào)中心對(duì)齊;相鄰兩行符號(hào)數(shù)差2;符號(hào)數(shù)先從大到小順序遞減到1,再?gòu)男〉酱箜樞蜻f增;首尾符號(hào)數(shù)相等。
給定任意N個(gè)符號(hào),不一定能正好組成一個(gè)沙漏。要求打印出的沙漏能用掉盡可能多的符號(hào)。
輸入描述:
輸入在一行給出1個(gè)正整數(shù)N(<=1000)和一個(gè)符號(hào),中間以空格分隔。
輸出描述:
首先打印出由給定符號(hào)組成的最大的沙漏形狀,最后在一行中輸出剩下沒用掉的符號(hào)數(shù)。
輸入例子:
200 *輸出例子:
************************************************************************************************************************************************************************************ ******************* 1 #include<iostream> using namespace std; int main() {//第n個(gè)沙漏,最長(zhǎng)一行需要2*n-1個(gè)*,總共需要2*n^2-1個(gè)*int n, num, total, rowmax;char symbol;cin >> num >> symbol;for (n = 0; 2 * n*n - 1 <= num; n++);total = 2 * (n - 1)*(n - 1) - 1;//the * we needrowmax = 2 * (n - 1) - 1;//the * in first row//打印前n行int i, j, k;for (i = 1; i < n; i++)//控制行{for (j = i - 1; j > 0; j--)//控制space{cout << " ";}for (k = 0; k < rowmax; k++)//控制symbol{cout << symbol;}rowmax -= 2;cout << endl;}//打印后n-1行for (i = 1; i < n - 1; i++){for (j = n - i - 2; j > 0; j--)//控制space{cout << " ";}for (k = 0; k < 2 * i + 1; k++)//控制symbol{cout << symbol;}cout << endl;}cout << num - total << endl;system("pause");return 0; }總結(jié)
以上是生活随笔為你收集整理的牛客网_PAT乙级_1017打印沙漏(20)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 牛客网_PAT乙级_1016程序运行时间
- 下一篇: 牛客网_PAT乙级_1018人口普查(2