蓝桥杯 历届试题 打印十字图

问题描述

小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:

..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..

对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。

输入格式

一个正整数 n (n<30) 表示要求打印图形的层数。

输出格式

对应包围层数的该标志。

样例输入1

1

样例输出1                                                                      

..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..

样例输入2

3

样例输出2

..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..

提示

请仔细观察样例,尤其要注意句点的数量和输出位置。

思路:

1.此题没有什么算法思想,纯粹是找规律,很明显这是一个对称图形,我们先可以分成4个部分(左上,右上,左下,右下)

规律:行列都是(n * 4 + 5)

2.所以我们只需要考虑左上即可

只考虑的部分:

                                                           

1、不管图形多大,左上角4个一定是点(i <= 2 && j <= 2)

                                                                        

2、再对此时的图形做对称,可以将右上的全部翻转到左下

                                                                                   

     当为奇数行时,由图看出,行列差2即可(i % 2 == 1 && j >= i - 2)                                      

                                                                      

4、当为奇数列时,不能有(2,1)(4,3)故规律为(j % 2 == 1 && j != i - 1)

 

#include <stdio.h>
void swap(int *a, int *b)
{
    int temp;
    temp = *a;
    *a = *b;
    *b = temp;
}

int go(int i, int j, int n)
{
    if (i > n * 2 + 3)//上下对称
        i = n * 4 + 6 - i;
    if (j > n * 2 + 3)//左右对称
        j = n * 4 + 6 - j;
    if (i < j)    //对角线右上部分和左下部分图形对称
        swap(&i, &j);
    if (i <= 2 && j <= 2) //四个小角
        return 0;
    if (i % 2 == 1 && j >= i - 2)//核心规律
        return 1;
    if (j % 2 == 1 && j != i - 1)//核心规律
        return 1;
    return 0;
}

int main()
{
    int n;
    scanf("%d", &n);

    int i, j;
    for (i = 1; i <= n * 4 + 5; i++)
    {
        for (j = 1; j <= n * 4 + 5; j++)
        {
            if (go(i, j, n))
                printf("$");
            else
                printf(".");
        }
        printf("\n");
    }

    return 0;
}

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值