[ 模拟 ] HPU 方框

本文介绍了一个使用二维数组绘制字符图形的方法,通过一层一层地填充字符来实现不同大小的方框图形输出,避免了复杂的行输出逻辑,使得代码更加简洁易懂。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方框

Description

 

用'*'打印出一个nxn的字符图形(1<=n<=100).

Input

 

多组输入。每行输入一个n,输入EOF结束文件.

Output

 

输出一个满足题意的图形.

Sample Input 1

1
2
5
6
10
11

Sample Output 1

*
**
**
*****
*   *
* * *
*   *
*****
******
*    *
* ** *
* ** *
*    *
******
**********
*        *
* ****** *
* *    * *
* * ** * *
* * ** * *
* *    * *
* ****** *
*        *
**********
***********
*         *
* ******* *
* *     * *
* * *** * *
* * * * * *
* * *** * *
* *     * *
* ******* *
*         *
***********

很有意思的输出图形题目,一开始总在想每一行每一行的输出,所以一直在找规律,就把自己找死了,今天再看这道题,突然发现,图形可以看作是一圈一圈围起来的,而且用二维数组来模图案会比每行输出方便得多,就很容易实现了,A掉


#include<bits/stdc++.h>
#pragma GCC optimize(2)
using namespace std;
#define maxn 105
#define mod 1e9+7
typedef long long ll;
ll n;
char A[maxn][maxn];
void slove(ll x,ll len)   //对正方形每个边填充
{
    for(ll i = x; i <= len+x-1; i++ ) //上
        A[x][i] = '*';
    for(ll i = x; i <= len+x-1; i++) //左
        A[i][x] = '*';
    for(ll i = x; i <= len+x-1; i++) //下
        A[x+len-1][i] = '*';
    for(ll i = x; i <= len+x-1; i++) //右
        A[i][x+len-1] = '*';
    return ;
}
int main()
{
    ios::sync_with_stdio(false);
    while(cin >> n)
    {
        memset(A,' ',sizeof(A));
        for(ll i = 1,len = n; i <= n; i += 2,len -= 4)
        {
            slove(i,len);  //len为正方形边长  i为正方形边的行列
        }
        for(ll i = 1; i <= n; i++)
        {
            for(ll j = 1; j <= n; j++)
            {
                cout << A[i][j];
            }
            cout << endl;
        }
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值