AtCoder Regular Contest 061
AtCoder Regular Contest 061
C.Many Formulas
题意
- 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S。
- 可以在两数字间放\(+\)号。
- 求所有方案的数字和。
思路
- \(2^{|S|-1}\)枚举加号的放置状态
代码
D.Snuke's Coloring
题意
- 在一个\(H \times W(3 \le H,W \le 10^9)\)的棋盘上,有\(N(N \le 10^5)\)个格子被染成黑色,其余格子为白色。
- 求在所有\(3 \times 3\)的子矩形中黑色格子个数分别为\(0,1,...,9\)的个数。
思路
- 考虑每个黑色格子作为\(3 \times 3\)矩形中的其中一个格子,求对应矩形的黑色格子数。如果当前矩形的黑色格子数为\(x\),则该格子会被计数\(x\)次。
- \(0\)的矩形个数由总方案减去有黑色格子的方案数。
代码
E.Snuke's Subway Trip
题意
- 一张图,有\(N(N \le 10^5)\)个点,\(M(M \le 2 \times 10^5)\)条边。
- 每条边有一种颜色\(c_i\)。
- 假设通过颜色\(i\)走到节点\(u\),当\(u\)要走到相邻节点时,如果经过的边仍为颜色\(i\),则费用为0,否则需要代价1。
- 求从节点1走到节点N的最小花费。
思路
- 假设与\(u\)有关的边的颜色有\(x\)种,则将点拆成\(u_{c1}, u_{c2},...,u_{cx}\)个点。
- 将点\(u\)设置成总点,与\(u_{ci}\)连边,费用为1。
- 假设\(u\)走到\(v\),颜色为\(C\),则\(u_C\)与\(v\)连边,费用为0;\(u_C\)与\(v_C\)连边,费用为0。
- 最后跑一遍单源最短路即可。
代码
F.Card Game for Three
题意
- Alice、Bob和Charlie分别有\(N,M,K(N,M,K \le 3 \times 10^5)\)张牌,每张牌有一个字母(a,b或c)。
- 三个人轮流出牌,牌上的数字代表下一个出牌的玩家。
- 若当前要出牌的玩家没有牌,则该玩家获胜。
- Alice先出牌,求在所有可能的方案中Alice获胜的方案数。
思路
- 出牌顺序看成一串abc的序列,第一个达到手牌上限的人获胜,假设Alice获胜,那么a出现了\(N+1\)次。因为Alice先手,所以第一个总是固定为a,那么去掉第一个后a出现\(N\)次。
- 考虑游戏结束时三个人共打出了\(i\)张牌,可以得到3个信息:
- 最后一张牌必然是a;
- b和c的出现次数不超过\(M,K\);
- b和c不会同时超出上限。
- 先从\(i-1\)选\(N-1\)位置放a;剩下的位置放置b和c,总方案数为\(2^{i-N}\),考虑去掉不合法的方案,即b或c超过上限的方案数,小数据可以暴力求,对于b来说,枚举\([M+1, i-N]\)的出现次数,c同理。对于大数据来说,假设长为\(i-1\)中b不合法的方案数为\(fb\),那么当前多了一个填充bc的位置,这个位置可以填bc,方案仍为不合法的方案,此时b的个数大于\(M+1\),还要求b的个数刚好为\(M+1\)的不合法方案数。
代码
AtCoder Regular Contest 061的更多相关文章
- AtCoder Regular Contest 061 DSnuke's Coloring
http://arc061.contest.atcoder.jp/tasks/arc061_b 题意: H行W列的矩阵中,然后挖了n个洞,输出j(0-9)行,对于第i行输出,有多少个3*3区域中有i个 ...
- Atcoder Regular Contest 061 D - Card Game for Three(组合数学)
洛谷题面传送门 & Atcoder 题面传送门 首先考虑合法的排列长什么样,我们考虑将每次操作者的编号记录下来形成一个序列(第一次 A 操作不计入序列),那么显然这个序列中必须恰好含有 \(n ...
- [Atcoder Regular Contest 061] Tutorial
Link: ARC061 传送门 C: 暴力$dfs$就好了 #include <bits/stdc++.h> using namespace std; typedef long long ...
- AtCoder Regular Contest 061 E - すぬけ君の地下鉄旅行【最短路】
具体题解又要搬大哥的了,嘿嘿~ 请点击:G点我 这道题目的难点就是同一家公司的路直接走不需要再花费,然后多了一个公司这个东西,这个不像是边的副权值(瞎说的)之类的东西,这是对于路来说的,路的属性... ...
- AtCoder Regular Contest 094 (ARC094) CDE题解
原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...
- AtCoder Regular Contest 092
AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...
- AtCoder Regular Contest 093
AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...
- AtCoder Regular Contest 094
AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...
- AtCoder Regular Contest 095
AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...
随机推荐
- struts中拦截器的开发
1.开发Interceptor类 用户自定义的拦截器一般需要继承AbstractInterceptor类,重写intercept方法 public class UserInterceptor exte ...
- [ASP.NET] 使用Loading遮罩防止使用者重複點擊
From: http://www.dotblogs.com.tw/joysdw12/archive/2012/12/13/85629.aspx 前言 在網頁執行中可能會因為資料量大或其他原因影響使用者 ...
- Program B--CodeForces 492B
Description Vanya walks late at night along a straight street of length l, lit by n lanterns. Consid ...
- Android EditText email、数字验证
在做Android注册登录模块的时候,经常需要在客户端就验证用户输入的信息的正确性,如填写邮箱需要验证是否是邮箱,填写手机.年龄等信息需要验证是否是数字.先介绍一下验证邮箱的代码: /** * met ...
- [转]Vimium快捷键
from: http://www.cppblog.com/deercoder/archive/2011/10/22/158886.html 今天下午折腾了一下Chrome下面的一个插件Vimium的使 ...
- innerHTML..innerText..textContent
/* * innerText和textContent 都是设置文字内容的,如果设置的内容当中有标签,也会直接的以文本的方式显示(标签的<>都会按照转义的方式进行解析) * innerTex ...
- Tomcat 网站部署(三)
一.Tomcat的部署方式有以下两种 1.自动部署 2.虚拟目录 二.自动部署 文件必须放在放在webapps就可以了,可以用这样访问 http://localhost:8080/放在webapps目 ...
- win8系统 host文件无法修改解决之道
host文件,路径为:C:\windows\system32\drivers\etc\hosts 方法/步骤: 方法1:用notepad++打开host文件,修改和保存 方法2:(1)首先用管理管权限 ...
- fix eclipse gc overhead limit exceeded in mac
fix eclipse gc overhead limit exceeded: 在mac上找不到eclipse.ini文件编辑内存限制,在eclipse安装目录右击eclipse程序,选“显示包内容” ...
- hdu 2028
PS:以前对long long型的数据就一直不怎么明白...弄了好久... long long a; scanf("%lld",&a); printf("%lld ...