【模拟】打印沙漏

描述

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印





所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入

输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。

输出

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

样例输入

19 *

样例输出





2

题目来源

PAT 乙级

分析:
模拟。
感受:
PTA的测试强度不够,支持TZOJ!
代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[25];
a[1]=1;
int d=3;
for (int i=2;i<=24;i++)
{
a[i]=a[i-1]+d2;
d+=2;
}
int w=1,n;
char c;
cin>>n>>c;
for (int i=2;i<=24;i++)
{
if (n>=a[i-1]&&n<a[i])
{
w=i-1;
break;
}
}
for (int i=w;i>=1;i–)
{
for (int j=0;j<w-i;j++)
cout<<’ ';
for (int j=0;j<2
i-1;j++)
cout<<c;
cout<<endl;
}
for (int i=2;i<=w;i++)
{
for (int j=0;j<w-i;j++)
cout<<’ ';
for (int j=0;j<2*i-1;j++)
cout<<c;
cout<<endl;
}
cout<<n-a[w]<<endl;
return 0;
}

发布了65 篇原创文章 · 获赞 0 · 访问量 1333

猜你喜欢

转载自blog.csdn.net/Skynamer/article/details/103954211