#include <iostream>
#include <cmath>
using namespace std;
int** game(int**a ,int n)
{
if(n==2)
{
a[0][0]=1;
a[0][1]=2;
a[1][0]=2;
a[1][1]=1;
return a;
}
for(int i=0;i<n/2;i++)
{
for(int j=0;j<n/2;j++)
{
a[i][j]=game(a,n/2)[i][j];
}
}
for(int i=n/2;i<n;i++)
{
for(int j=0;j<n/2;j++)
{
a[i][j]=game(a,n/2)[i-n/2][j]+n/2;
}
}
for(int i=0;i<n/2;i++)
{
for(int j=n/2;j<n;j++)
{
a[i][j]=game(a,n/2)[i][j-n/2]+n/2;
}
}
for(int i=n/2;i<n;i++)
{
for(int j=n/2;j<n;j++)
{
a[i][j]=game(a,n/2)[i-n/2][j-n/2];
}
}
return a;
}
int main()
{
cout<<"输入比赛人数的幂指数k(N=2~k)"<<endl;
int k;
cin>>k;
int n=pow(2*1.0,k);
cout<<"比赛总人数为"<<n<<endl;
int **a=new int*[n];
for(int i=0;i<n;i++)
{
a[i]=new int[n];
}
for(int i=0;i<n;i++)
{
for (int j=0;j<n;j++)
{
a[i][j]=0;
}
}
game(a,n);
for(int i=0;i<n;i++)
{
for (int j=0;j<n;j++)
{
cout<<a[i][j]<<" ";
}
cout<<endl;
}
_sleep(10000);
for(int i=0;i<=n;i++)
{
delete[] a[i];
}
delete[] a;
system("pause");
}
分治法求循环赛日程问题
最新推荐文章于 2024-07-31 18:26:14 发布