【蓝桥杯】打印十字图 找规律文字打印

    技术2023-08-18  102

    问题描述

    小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示: 对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。

    输入

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

    输出

    对应包围层数的该标志。

    样例

    输入:1,3 输出:

    【想说的】:打印的题目其实都没有很怕,就是一葫芦画瓢,找到规律打印,但是这个题目有一个巧妙的地方,其实以前用过这个技巧,有点忘记了,就是整体的去看这个图形,修改数组的值,最后整个数组输出。 【启示】一层一层去剖析,发现十字架除掉转角的部分其实很好构造,就是横着竖着的部分,规律也很明显,然后再去逐个实现转角。(挺巧妙的!)

    题解

    #include <iostream> #include <cstdio> #include <algorithm> #include <math.h> #include <cstring> #include <string> #include <map> #include <set> #include <queue> #include <stack> #include <vector> using namespace std; char pic[130][130]; int main() { int n; while(~scanf("%d",&n)) { memset(pic,'.',sizeof(pic)); int m=4*n+5; int tem=m/2; for(int i=1;i<=2;i++) { pic[tem][tem+i]='$'; pic[tem][tem-i]='$'; pic[tem+i][tem]='$'; pic[tem-i][tem]='$'; } pic[tem][tem]='$'; int k=1; int nn=n; int ls=0; int lx=m-1; while(k<=n) { for(int i=0;i<4*nn+1;i++) { pic[ls][2*k+i]='$'; pic[lx][2*k+i]='$'; pic[2*k+i][ls]='$'; pic[2*k+i][lx]='$'; } pic[ls+1][2*k]='$';pic[ls+2][2*k]='$';pic[ls+2][2*k-1]='$'; pic[lx-1][2*k]='$';pic[lx-2][2*k]='$';pic[lx-2][2*k-1]='$'; pic[lx-1][m-2*k-1]='$';pic[lx-2][m-2*k-1]='$';pic[lx-2][m-2*k]='$'; pic[2*k][lx-1]='$';pic[2*k][lx-2]='$';pic[2*k-1][lx-2]='$'; ls+=2; lx-=2; k++; nn--; } for(int i=0;i<m;i++) { for(int j=0;j<m;j++) { printf("%c",pic[i][j]); } printf("\n"); } } }
    Processed: 0.011, SQL: 10