1. 程式人生 > 其它 >L1-002 列印沙漏

L1-002 列印沙漏

技術標籤:PTA:團體程式設計天梯賽-練習集c++

題目:

本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個“*”,要求按下列格式列印:

所謂“沙漏形狀”,是指每行輸出奇數個符號;各行符號中心對齊;相鄰兩行符號數差2;符號數先從大到小順序遞減到1,再從小到大順序遞增;首尾符號數相等。

給定任意N個符號,不一定能正好組成一個沙漏。要求打印出的沙漏能用掉儘可能多的符號。

輸入格式:

輸入在一行給出1個正整數N(≤1000)和一個符號,中間以空格分隔。

輸出格式:

首先打印出由給定符號組成的最大的沙漏形狀,最後在一行中輸出剩下沒用掉的符號數。

輸入樣例:

19 *

輸出樣例:

程式碼實現

//我的程式碼中,每個空格都打印出來了
#include <iostream>
#include <cmath>
using namespace std;
int main(){
    int N; //正整數 N ≤1000
    char c; //一個符號 
    int m; //m行
    int n; //每行n個符號
    int sum=1;
	cin >> N >> c;
    if(N<=0 || N>1000)
    	cout << "Error" << endl;	
	else
{ for(int i=1;;i++){ //確定行數m n = 2*i + 1; sum=sum+2*n; //或 sum = 2*i*i + 4*i + 1; m=2*i-1; if(sum>N) break; } int t; int k=0; for(int i=m/2;i>=-m/2;i--){ for(int j=m/2; j>=-m/2; j--){ if(abs(j)>abs(i)) cout << " "; else{ cout << c; k++
; } } cout << endl; } t = N-k; cout << t; } return 0; }