#include <iostream>
#include <cstdio>
using namespace std;
#define MAXN 10000
int a[MAXN][MAXN];
void func(int start,int length)
{
int i,j;
int len=length/2;
if(len==1)
{
a[start+1][2]=a[start][1];
a[start][2]=a[start+1][1];
return ;
}
func(start,len);
func(start+len,len);
for(i=start;i<start+len;i++)
for(j=1;j<=len;j++)
a[i+len][j+len]=a[i][j];
for(i=start+len;i<start+2*len;i++)
for(j=1;j<=len;j++)
a[i-len][j+len]=a[i][j];
}
int main()
{
int n;
int i,j;
scanf("%d",&n);
for(i=1;i<=n;i++)
a[i][1]=i;
func(1,n);
for(i=1;i<=n;i++)
{
for(j=1;j<n;j++)
cout<<a[i][j]<<" ";
cout<<a[i][j]<<endl;
}
return 0;
}
循环赛日程表
猜你喜欢
转载自blog.csdn.net/xigongdali/article/details/82631702
今日推荐
周排行