循环赛日程表--C语言

 

#include<stdio.h>
#include<math.h>
void gametable(int k)
{       
    int a[100][100];
    int n,temp,i,j,p,t;
    n=2;//k=0两个参赛选手日程可以直接求得
    a[1][1]=1;a[1][2]=2;
    a[2][1]=2;a[2][2]=1;


    for(t=1;t<k;t++)//迭代处理,依次处理2^n....2^k个选手的比赛日程
    {
        temp=n;n=n*2;//填左下角元素
        for(i=temp+1;i<=n;i++)
            for(j=1;j<=temp;j++)
                a[i][j]=a[i-temp][j]+temp;//左下角和左上角元素的对应关系
        for(i=1;i<=temp;i++)//将左下角元素抄到右上角
            for(j=temp+1;j<=n;j++)
                a[i][j]=a[i+temp][(j+temp)%n];
        for(i=temp+1;i<=n;i++)//将左上角元素抄到右下角
            for(j=temp+1;j<=n;j++)
                a[i][j]=a[i-temp][j-temp];
     
    }
    printf("参赛人数为:%d\n(第i行第j列表示和第i个选手在第j天比赛的选手序号)\n",n);
    for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        {
            printf("%d ",a[i][j]);
                if(j==n)


                printf("\n");
        
        }
}
void main()
{
    int k;
    printf("比赛选手个数为n(n=2^k),请输入参数K(K>0):\n");
    scanf("%d",&k);
    if(k!=0)
    gametable(k);
    
}

 

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
循环赛日程表问题是一个经典的组合数学问题,它的目标是设计一个比赛日程表,使得n个队伍两两之间都要比赛一次,且每个队伍每天只能进行一次比赛。这个问题可以使用分治算法解决。 下面是循环赛日程表分治算法的C语言代码实现: ```c #include<stdio.h> void Schedule(int **a, int n, int k) { if (n == 2) { a = 1; a = 2; a = 2; a = 1; } else { Schedule(a, n / 2, k); int i, j; for (i = 1; i <= n / 2; i++) { for (j = k + 1; j <= k + n / 2; j++) { a[i][j] = a[i + n / 2][j - n / 2]; } } for (i = n / 2 + 1; i <= n; i++) { for (j = k + 1; j <= k + n / 2; j++) { a[i][j] = a[i - n / 2][j - n / 2]; } } for (i = 1; i <= n / 2; i++) { for (j = k + n / 2 + 1; j <= k + n; j++) { a[i][j] = a[i + n / 2][j - n / 2 - 1] + n / 2; } } for (i = n / 2 + 1; i <= n; i++) { for (j = k + n / 2 + 1; j <= k + n; j++) { a[i][j] = a[i - n / 2][j - n / 2 - 1] + n / 2; } } Schedule(a, n / 2, k + n / 2); } } int main() { int n, i, j; printf("请输入参赛队伍数量:"); scanf("%d", &n); int **a = (int **) malloc((n + 1) * sizeof(int *)); for (i = 1; i <= n; i++) { a[i] = (int *) malloc((n + 1) * sizeof(int)); } Schedule(a, n, 0); printf("比赛日程表如下:\n"); for (i = 1; i <= n; i++) { for (j = 1; j <= n; j++) { printf("%d ", a[i][j]); } printf("\n"); } return 0; } ``` 该算法的思路是先把问题规模缩小到n/2,然后将n/2个队伍分成两组,第一组与第二组之间的比赛日程表可以由上一步得到,第一组与第三组之间、第二组与第四组之间的比赛日程表可以通过对上一步得到的日程表进行调整得到。然后再把问题规模缩小到n/4,重复上述过程,直到问题规模缩小到2。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值