首页 > 代码库 > Codeforces Round #261 (Div. 2)——Pashmak and Buses
Codeforces Round #261 (Div. 2)——Pashmak and Buses
题目链接
- 题意:
n个人,k个车,d天。每个人每天可以坐任意一个车,输出一种情况保证:不存在两个人,每天都在同一辆车上
(1?≤?n,?d?≤?1000; 1?≤?k?≤?109). - 分析:
比赛中用的方法麻烦至极。。。基本想法是均分,这样答案肯定比较优。第一天分到同一辆车上的人在第二天再均分,一直到结束即可
学习了别人的方法:一个人在全部d天中每天坐哪辆车,可以表示为d位k进制数x。那么2个人每天都在同一辆车上,就是两个人的x相等。所以我们只要构造出n个不同的d位k进制数就行
这个方法就很简单了。。。。
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; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。