解题思路:
本来想用递归,结果有点麻烦,还是用了暴力打表,以为会超时,结果没有
注意事项:
两个输出DNA有一行空格,第一次漏掉了
参考代码:
#include<stdio.h>
int main()
{
int n;
int a,b;
scanf("%d",&n);
while(n--)
{
scanf("%d %d",&a,&b);
char d[a][a];
for(int k=b;k>0;k--)#重复次数
{
for(int i=0;i<a-1;i++)#每次重复相同打表行数,例子里的5的话那就0-3行相同打表
{
for(int j=0;j<a;j++)
{
d[i][j]=' ';#每行初始化
}
d[i%a][i%a]='X';
d[i%a][a-1-i%a]='X';#标记所在的位置,直接可以用i,不用余数也是可以的
for(int j=0;j<a;j++)#打表一行直接输出
printf("%c",d[i][j]);
printf("\n");
}
}
d[0][0]=d[0][a-1]='X';#重复所有后还有最后一行没有输出,这里直接输出最后一行
for(int j=1;j<a-1;j++)
{
d[0][j]=' ';
}
for(int j=0;j<a;j++)
printf("%c",d[0][j]);
printf("\n");
printf("\n");#这里记得再换行,因为两个输出结果之间要有空行
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复