A - Rikka with Nash Equilibrium

题意:构造一个$n * m$的矩阵,使得$[1, n * m]$ 中每个数只出现一次,并且纳什均衡只出现一次。

思路:从大到小的放置,每一个都可以拓展一行拓展一列或者放在已经拓展的行列焦点,用记忆化搜索/dp即可

 #include<bits/stdc++.h>

 using namespace std;

 typedef long long ll;

 int n, m;
ll p;
ll dp[][][ * ]; ll DFS(int x, int y,int z)
{
if(z >= n * m) return ;
if(dp[x][y][z] != -) return dp[x][y][z];
ll res = ;
if(x < n) res = (res + y * (n - x) % p * DFS(x + , y, z + )) % p;
if(y < m) res = (res + x * (m - y) % p * DFS(x, y + , z + )) % p;
if(x * y > z) res = (res + (x * y - z) * DFS(x, y, z + )) % p;
dp[x][y][z] = res;
return res;
} int main()
{
int t;
scanf("%d", &t);
while(t--)
{
scanf("%d %d %lld", &n, &m, &p);
memset(dp, -, sizeof dp);
ll ans = DFS(, , );
ans = n * m % p * ans % p;
printf("%lld\n", ans);
}
return ;
}

B - Rikka with Seam

留坑。

C - Rikka with APSP

留坑。

D - Rikka with Stone-Paper-Scissors

题意:每个人有三种牌,"石头、剪刀、布" ,询问第一个人赢第二个人的期望

思路:考虑每一次出牌的概率相同,那么答案就是(赢的情况种数 - 输的情况) / 牌数   那么所有赢输情况种类数就是 $\frac {a_1 *(b_2 - c_2) + b_1 * (c_2 - a_2) + c_1 * (a_2 - b_2)} {a + b + c} $

 #include<bits/stdc++.h>

 using namespace std;

 typedef long long ll;

 ll gcd(ll a, ll b)
{
return b == ? a : gcd(b, a % b);
} ll a1, b1, c1, a2, b2, c2; int main()
{
int t;
scanf("%d", &t);
while(t--)
{
scanf("%lld %lld %lld %lld %lld %lld", &a1, &b1, &c1, &a2, &b2, &c2);
ll ans = a1 * (b2 - c2) + b1 * (c2 - a2) + c1 * (a2 - b2);
if(ans % (a1 + b1 + c1) == )
{
ans /= a1 + b1 + c1;
printf("%lld\n", ans);
}
else
{
int flag = ;
if(ans < )
{
ans = -ans;
flag = ;
}
ll ans2 = a1 + b1 + c1;
ll GCD = gcd(ans, ans2);
ans /= GCD;
ans2 /= GCD;
if(flag) printf("-");
printf("%lld/%lld\n", ans, ans2);
}
}
return ;
}

E - Rikka with Rain

留坑。

F - Rikka with Spanning Tree

留坑。

G - Rikka with Treasure

留坑。

H - Rikka with Line Graph

留坑。

I - Rikka with Bubble Sort

留坑。

J - Rikka with Time Complexity

留坑。

K - Rikka with Badminton

题意:四种人,一种人啥都没有,一种人有拍,一种人有球,一种人有拍有球,求方案数使得有两拍一球

思路:考虑三种选择方案

1° 两个有拍+一个有球

2°两个有拍有球

3°一个有拍,一个有拍有球

答案就是$2^a \cdot 2^c \cdot (2^b - 1) \cdot (2^d - 1) + 2^a \cdot 2^c \cdot (2^d - 1 - d) + 2^a \cdot (2^b - 1 - b) \cdot (2^c - 1)$

 #include <bits/stdc++.h>
using namespace std; #define ll long long const ll MOD = ; ll qmod(ll n)
{
ll res = ;
ll base = ;
while (n)
{
if (n & ) res = res * base % MOD;
base = base * base % MOD;
n >>= ;
}
return res;
} int t;
ll a, b, c, d; int main()
{
scanf("%d", &t);
while (t--)
{
scanf("%lld%lld%lld%lld", &a, &b, &c, &d);
ll n = a + b + c + d;
ll res = qmod(a) * qmod(c) % MOD * (qmod(b) - + MOD) % MOD * (qmod(d) - + MOD) % MOD;
res = (res + qmod(a) * qmod(c) % MOD * (qmod(d) - - d + MOD) % MOD) % MOD;
res = (res + qmod(a) * (qmod(b) - - b + MOD) % MOD * (qmod(c) - + MOD)) % MOD;
printf("%lld\n", (qmod(n) - res + MOD) % MOD);
}
return ;
}

2018 Multi-University Training Contest 9 Solution的更多相关文章

  1. 2018 Multi-University Training Contest 1 Solution

    A - Maximum Multiple 题意:给出一个n 找x, y, z 使得$n = x + y +z$ 并且 $n \equiv 0 \pmod x, n \equiv 0 \pmod y, ...

  2. 2018 Multi-University Training Contest 2 Solution

    A - Absolute 留坑. B - Counting Permutations 留坑. C - Cover 留坑. D - Game puts("Yes") #include ...

  3. 2018 Multi-University Training Contest 3 Solution

    A - Problem A. Ascending Rating 题意:给出n个数,给出区间长度m.对于每个区间,初始值的max为0,cnt为0.遇到一个a[i] > ans, 更新ans并且cn ...

  4. 2018 Multi-University Training Contest 4 Solution

    A - Problem A. Integers Exhibition 留坑. B - Problem B. Harvest of Apples 题意:计算$\sum_{i = 0}^{i = m}C( ...

  5. 2018 Multi-University Training Contest 5 Solution

    A - Always Online Unsolved. B - Beautiful Now Solved. 题意: 给出一个n, k  每次可以将n这个数字上的某两位交换,最多交换k次,求交换后的最大 ...

  6. 2018 Multi-University Training Contest 6 Solution

    A - oval-and-rectangle 题意:给出一个椭圆的a 和 b,在$[0, b]中随机选择c$ 使得四个顶点在椭圆上构成一个矩形,求矩形周长期望 思路:求出每种矩形的周长,除以b(积分) ...

  7. 2018 Multi-University Training Contest 7 Solution

    A - Age of Moyu 题意:给出一张图,从1走到n,如果相邻两次走的边的权值不同,花费+1, 否则花费相同,求最小花费 思路:用set记录有当前点的最小花费有多少种方案到达,然后最短路 #i ...

  8. 2018 Multi-University Training Contest 8 Solution

    A - Character Encoding 题意:用m个$0-n-1$的数去构成k,求方案数 思路:当没有0-n-1这个条件是答案为C(k+m-1, m-1),减去有大于的关于n的情况,当有i个n时 ...

  9. 2018 Multi-University Training Contest 10 Solution

    A - Problem A.Alkane 留坑. B - Problem B. Beads 留坑. C - Problem C. Calculate 留坑. D - Problem D. Permut ...

随机推荐

  1. python2.0_s12_day9_协程&多线程和cpu,磁盘io之间的关系

    事件驱动和异步io有什么直接关系. 当我们访问一个网页,不考虑网络问题.我们人类不觉得网页慢. 但是实际中对计算机来说还是慢.那慢在哪里.io io操作是整个网络操作中最慢的.比如你打开网页要是有2秒 ...

  2. window 后台执行 redis(隐藏窗口)

    方法是在知乎上看的,链接:https://www.zhihu.com/question/22771030 实现方法是利用一个vbe脚本去运行一个bat脚本,在bat脚本里启动exe软件 PS:要想启动 ...

  3. 【Mysql】解决插入数据出现 Incorrect string value: '\xF0\x9F\x92\x8BTi...'错误

    背景: 用户输入的表单里边.存在 手机自带的表情,  在执行插入时候报错 Incorrect string value: '\xF0\x9F\x92\x8BTi...' 错误原因:我们在设置mysql ...

  4. Day05_C操作符及二进制补码计算

    回顾:  1.数据类型  2.二进制(八进制,十六进制) --------------------------------------------------------- 计算机中不可以使用负号表示 ...

  5. java基础---->摘要算法的介绍

    数据摘要算法是密码学算法中非常重要的一个分支,它通过对所有数据提取指纹信息以实现数据签名.数据完整性校验等功能,由于其不可逆性,有时候会被用做敏感信息的加密.数据摘要算法也被称为哈希(Hash)算法. ...

  6. MQTT 3.1协议非严肃反思录

    前言 MQTT 3.1协议在弱网络环境下(比如2G/3G等)表现不够好,因此才有了反思. 弱网环境下表现 手机等终端在弱网络环境下丢包情况会非常明显,连接MQTT Server成功率很低.相比单纯的请 ...

  7. poj3744 Scout YYF I[概率dp+矩阵优化]

    Scout YYF I Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8598   Accepted: 2521 Descr ...

  8. all index range ref eq_ref const system 索引type说明

    背景知识 在使用sql的过程中经常需要建立索引,而每种索引是怎么处罚的又是怎么起到作用的,首先必须知道索引和索引的类型. 索引类型type 我们可以清楚的看到type那一栏有index ALL eq_ ...

  9. Sublime Text 3配置Minify压缩,格式化css,js,html,json,svg

    1.通过 Package Control 安装Minify 按 ctrl + shift + p   输入  Install Package 然后   输入Minify  按回车就可以安装啦 2.安装 ...

  10. rest_framework之规范详解 00

    接口开发 方式1:缺点:如果有10张表,则需要40个url. urls.py views.py 缺点:如果有10张表,则需要40个url.    接下来就出现了resrful 规范,比较简洁 方式2: ...