解题思路:
注意事项:
参考代码:
#include<stdio.h>
typedef struct DNA
{
int a;
int b;
}D;
D DA[1025];
void fun(int i)
{
int control,controls=1; //controls==0,则control自减
int m;
int blank_number;
int j,DNA_number=0;
for(j=0,control=0; DNA_number<DA[i].b ; j++)
{
if(j==DA[i].a-1 || j==0)
{
for(m=1;m<=DA[i].a;m++)
{
if(m==1)
printf("X");
else if(m==DA[i].a)
printf("X\n");
else
printf(" ");
}
if(j==DA[i].a-1)
j=0,DNA_number++ , control=0;
controls=1;
control++;
}
else if(j==DA[i].a/2) //处理每个DNA中间的图像(只有一个x)
{
for(m=0;m<DA[i].a;m++)
{
if(m==DA[i].a/2)
printf("X");
else
printf(" ");
}
control--;controls=0;
printf("\n");
}
else
{
for(m=1;m<=control;m++)
{
printf(" ");
}
printf("X");
blank_number=DA[i].a-2*(control)-2;
for(m=1;m<=blank_number;m++)
printf(" ");
printf("X\n");
if(controls==0)
control--;
else if(controls==1)
control++;
}
}
}
int main()
{
int n,i=0;
scanf("%d",&n);
for(;i<n;i++)
scanf("%d %d",&DA[i].a,&DA[i].b);
for(i=0;i<n;i++)
fun(i),printf("\n");
return 0;
}
0.0分
0 人评分
【回文数(二)】 (C++代码)浏览:866 |
C二级辅导-计负均正 (C语言代码)浏览:647 |
【亲和数】 (C语言代码)浏览:539 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:411 |
【亲和数】 (C语言代码)浏览:856 |
C语言程序设计教程(第三版)课后习题1.5 (C++代码)浏览:1078 |
简单的a+b (C语言代码)浏览:573 |
C二级辅导-温度转换 (C语言代码)浏览:719 |
快速排序算法1浏览:884 |
多组数据新方法浏览:355 |