http://acm.hdu.edu.cn/showproblem.php?pid=4671

这个高端的题意啊 看了N久啊

n>m时  直接第一列按顺序来 第二列为M+1

else  第一列顺序来 第二列 按第一组为N  第二组为N-1  依次分配

hdu4671Backup Plan_phphdu4671Backup Plan_i++_02
 1 #include <iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<algorithm>
 5 #include<stdlib.h>
 6 using namespace std;
 7 #define N 110
 8 int f[110][110],a[110][110],x[110];
 9 int main()
10 {
11     int i,j,k,n,m;
12     while(cin>>n>>m)
13     {
14         memset(f,0,sizeof(f));
15         if(n>m)
16         {
17             for(i = 1; i <= m ; i++)
18             {
19                 a[i][1] = i;
20                 f[i][i] = 1;
21             }
22             for(i = 1 ; i <= m ; i++)
23             {
24                 a[i][2] = m+1;
25                 f[i][m+1] = 1;
26             }
27             for(i = 1; i <= m ; i++)
28             {
29                 printf("%d %d",a[i][1],a[i][2]);
30                 for(j = 1; j  <= n ; j++)
31                 {
32                     if(!f[i][j])
33                     printf(" %d",j);
34                 }
35                 puts("");
36             }
37         }
38         else
39         {
40             int j = 1;
41             for(i = 1; i <= m ; i++)
42             {
43                 f[i][j]  = 1;
44                 a[i][1] = j++;
45                 if(j>n)
46                 j = 1;
47             }
48             for(i = 1; i <= n ; i++)
49             x[i] = n;
50             j = 1;
51             for(i = 1; i <= m ; i++)
52             {
53                 int o = a[i][1];
54                 if(o == x[j])
55                 x[j]--;
56                 if(x[j]<1) x[j] = n;
57                 f[i][x[j]] = 1;
58                 a[i][2] = x[j]--;
59                 if(x[j]<1)
60                 x[j] = n;
61                 j++;
62                 if(j>n) j = 1;
63             }
64             for(i = 1; i <= m ; i++)
65             {
66                 printf("%d %d",a[i][1],a[i][2]);
67                 for(j = 1; j  <= n ; j++)
68                 {
69                     if(!f[i][j])
70                     printf(" %d",j);
71                 }
72                 puts("");
73             }
74         }
75     }
76     return 0;
77 }
View Code