传送门: http://www.dotcpp.com/oj/problem1115.html
问题 1115: DNA
时间限制: 1Sec 内存限制: 128MB 提交: 778 解决: 205
题目描述
小强从小就喜欢生命科学,他总是好奇花草鸟兽从哪里来的。终于, 小强上中学了,接触到了神圣的名词–DNA.它有一个双螺旋的结构。这让一根筋的小强抓破头皮,“要是能画出来就好了” 小强喊道。现在就请你帮助他吧
输入
输入包含多组测试数据。第一个整数N(N<=15),N表示组数,每组数据包含两个整数a,b。a表示一个单位的DNA串的行数,a为奇数且 3<=a<=39。b表示重复度(1<=b<=20)。
输出
输出DNA的形状,每组输出间有一空行。
样例输入
2
3 1
5 4
样例输出
X X
X
X X
X X
X X
X
X X
X X
X X
X
X X
X X
X X
X
X X
X X
X X
X
X X
X X
模拟
我是对角计算
1 从左上角 (0,0) 到 (n-1, n-1)
2 从坐下角(n-1,0) 到 (0, n-1)
1个大坑 图形是X(大写) 不是x
code :
#include <iostream>
#include <algorithm>
#include <cstring>
#include <string>
#include <cmath>
#include <cstdio>
using namespace std;
char a[103][103];
void x(int n)
{
a[0][0]='X';
a[n-1][0] = 'X';
int x = 0, y = 0;
while (x<n-1)
{
x++;
y++;
a[x][y] = 'X';
}
x = n-1; y=0;
while (y<n-1&&x>0)
{
x--;
y++;
a[x][y] = 'X';
}
}
int main()
{
int N;
scanf("%d",&N);
while (N--)
{
int n,num;
scanf("%d%d",&n,&num);
for (int i=0; i<n; i++)
for (int j=0; j<n; j++)
{
a[i][j]=' ';
}
x(n);
for (int i=0; i<num; i++)
{
int j;
if (i==0)
j=0;
else
j=1;
for (j; j<n; j++)
{
for (int k=0; k<n; k++)
{
printf ("%c",a[j][k]);
}
printf ("\n");
}
}
printf ("\n");
}
return 0;
}
/*
for (int i=0; i<n; i++)
{
x(n);
for (int j=0; j<n; j++)
{
for (int k=0; k<n; k++)
{
printf ("%c",a[j][k]);
}
printf ("\n");
}
}
*/