题目:
peter喜欢玩数字游戏,但数独这样的游戏对他来说太简单了,于是他准备玩一个难的游戏。游戏规则是在一个N*N的表格里填数,规则:对于每个输入的N,从左上角开始,总是以对角线为起点,先横着填,再竖着填。这里给了一些样例,请在样例中找到规律并把这个N*N的表格打印出来吧。 输入描述: 多组测试数据(数据量在100组以内)。每组测试数据只有一行为一个整数N(1<=N<=30),表示表格的大小。 输出描述: 对于每组输入数据,输出N行,为填完的表格(N行,每行N个整数,每个数字之间用空格隔开。
#include<iostream>
#include<fstream>
using namespace std;
void fill(int N)
{
int a[31][31];
int i,j;
int buff=1;
for(i=0;i<N;i++)
{
for(j=i;j<N;j++)
{
a[i][j] = buff++;
}
for(j=i+1;j<N;j++)
{
a[j][i] = buff++;
}
}
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
cout<<a[i][j]<<" ";
}
cout<<endl;
}
}
int main()
{
int N;
freopen("test.txt","r",stdin);
while(cin>>N)
fill(N);
}
result.txt
3
5
run:
--------------------------------------------------------------------------------------------
本来是想用迭代思想的,及每次先填写横再填竖,这是一个相似的操作,
所以用了一个for循环完成的