解题思路:1、利用两个数组进行操作,可以把DNA的规律进行保存(两个规律):(我把0当作空格)

举个例子:

X000X

0X0X0

00X00

0X0X0

X000X

不知道大家有没有发现,规律1:在X左边的0的个数向下依次形成0,1,2,1,0,接下来继续是,1,2,1,0...往复下去,形成,0,1,2,1每4次循环一次,用数组a保存起来,循环条件为a/2(因为2最大不超过a的一半,即2为中间的数); for(i=0;i<a/2;i++) 用来保存0,1,2;for(int aa=a/2;aa>=1;aa--,i++) 用来保存中间数后面剩余的数。(空格规律的长度为a-1

规律2:两头”X“夹着的空格,个数形成的规律是3,1,0,1,3,1,0,1...可以看出是3,1,0,1;每个数相差2,保存在数组b中,同理,因为3最大,而且3等于(a-2);for(i=a-2;i>=0;i-=2,k++) 用来保存3,1;而0单独保存跟在后面b[k]=0;k++;而0后面数则用for(i=1;i<a-2;i+=2,k++) 进行保存。

规律3:输出的结果都是与行数重复度有关联的,例如5行4重复,长度为17行,17=5*4-4+1;

因为从前面的2个规律看出,我们是可以不用控制什么时候结束的,我们只需要控制两个数组一直在规律之间往复循环就可以了。         

还有就是最右边的空格完全不用管,就当是摆设。     


注意事项:

1、注意每次输入新的数的时候,都需要初始化部分数值

2、别忘了题目要求的换行

3、”X“是大写,实在看不出来的可以复制个”X“到文本中看就知道了。

参考代码:

#include<iostream>

#include<algorithm>

#include<stdio.h>

#include<string.h>

#include<math.h>

using namespace std;

int main()

{

          int n,x,y,aa,c=0,k=0,d=0; //定义,d控制数组循环

          int a[1000],b[1000],i,j,r,t;

          cin>>n;

          while(1)

         {

                  k=0;                     //每次都初始化

                 if(n<=0) break;          //循环退出条件

                cin>>x>>y;               //输入

                for(i=0;i<x/2;i++)       //保存控制左边的空格

                       a[i]=i;

                for(aa=x/2;aa>=1;aa--,i++)   //保存控制左边空格

                      a[i]=aa;

                for(i=x-2;i>=0;i-=2,k++)     //保存控制中间的空格

                       b[k]=i;

                b[k]=0;k++;                 //中间0单独保存,k自增1次

               for(i=1;i<x-2;i+=2,k++) 

                       b[k]=i;

               c=0;k=0;d=0;           //每次都初始化,使其数组下标从0开始

              for(i=0;i<x*y-y+1;i++)   //总行数

                {

                      for(r=0;r<a[c];r++)   //控制左边空格的输出

                            cout<<" ";

                      cout<<"X";      //只输出一次

                      for(t=0;t<b[k];t++)   //控制中间空格的输出

                           cout<<" ";

                      if(b[k]!=0)           //如果b[k]不等于0,那么在X图案的对称中心就会有2个大x在一起,但是只有一个。

                             cout<<"X";  //末尾直接加“X”即可!

                      cout<<endl; //换行

                      c++;k++;d++; //每次输出完一行自增1

                       if(d==x-1)      //让数组进行循环,左边的空格规律的个数是X-1,满足后执行语句

                           {

                               c=0;k=0;d=0;  //满足条件之后数组又重新开始。

                           }

            }

                       cout<<endl; //记住题目的要求空出一行

                        n--;   //判断退出整个循环

      }

                     return 0;

}



















点赞(2)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论