循环赛日程表

#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