- 题意:
n个人,k个车,d天。每一个人每天能够坐随意一个车。输出一种情况保证:不存在两个人,每天都在同一辆车上
(1 ≤ n, d ≤ 1000; 1 ≤ k ≤ 109). - 分析:
比赛中用的方法麻烦至极。。。基本想法是均分,这样答案肯定比較优。第一天分到同一辆车上的人在第二天再均分,一直到结束就可以
学习了别人的方法:一个人在所有d天中每天坐哪辆车,能够表示为d位k进制数x。那么2个人每天都在同一辆车上,就是两个人的x相等。所以我们仅仅要构造出n个不同的d位k进制数即可
这种方法就非常easy了。。。。
const int MAXN = 1100; int n, k, d;
int ans[MAXN][MAXN];
bool fun()
{
REP(i, n)
{
int x = i;
REP(j, d)
{
ans[j][i] = x % k;
x /= k;
}
if (x > 0)
return false;
}
return true;
} int main()
{
while (~RIII(n, k, d))
{
if (!fun())
puts("-1");
else
{
REP(i, d) REP(j, n)
printf("%d%c", ans[i][j] + 1, " \n"[j == n - 1]);
}
}
return 0;
}