zoukankan      html  css  js  c++  java
  • 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进制数即可
      这种方法就非常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, " 
    "[j == n - 1]);
            }
        }
        return 0;
    }
    


  • 相关阅读:
    zabbix:乱码问题
    zabbix--微信报警(未完成)
    ansible-playbook项目(4)
    ansible-playbook(3)
    备份和校验脚本-邮件通知
    rsync
    keepalived
    双机热备
    nginx负载均衡
    LNMP(5)
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/5182682.html
Copyright © 2011-2022 走看看