CodeChef-LECOINS Little Elephant and Colored Coins 题解
CodeChef-LECOINS Little Elephant and Colored Coins
Little Elephant and Colored Coins
The Little Elephant from the Zoo of Lviv very likes coins. But most of all he likes colored coins.
He has N types of coins, numbered from 1 to N, inclusive. The coin of the i-th type has the value Vi dollars and the color Ci. Note that he has infinite supply of each type of coins.
The Little Elephant wants to make exactly S dollars using the coins. What is the maximal number of different colors he can use to make exactly S dollars using some of the coins he has? If it's impossible, output -1. Also note that the Little Elephant wants to know this for many values of S.
Input
The first line of the input contains a single integer N, denoting the number of types of coins. Each of the following N lines contains two space-separated integers Vi and Ci, denoting the value and the color of the coin of the i-th type. The next line contains a single integer Q, denoting the number of values of S to process. Each of the following Q lines contains a single integer S, denoting the coinage you should represent via given coins using maximum number of colors.
Output
For each value of S in the input, output the maximum number of different colors in the representation of S or -1 if it is impossible to represent S via given coins.
Constraints
- 1 ≤ N ≤ 30
- 1 ≤ Vi ≤ 200000 (2 * 10^5)
- 1 ≤ Ci ≤ 10^9
- 1 ≤ Q ≤ 200000 (2 * 10^5)
- 1 ≤ S ≤ 10^18
Example
Input:
3
2 1
3 4
4 4
4
1
3
5
7
Output:
-1
1
2
2
Explanation
- It is not possible to represent S = 1 since every coin has value more than 1.
- S = 3 can only be represented using one coin of the second type, hence only one color is used in the representation.
- S = 5 can only be represented as 2 + 3, which leads to two colors used.
- For S = 7 we have two representations as 2 + 2 + 3 (with two colors used) and 3 + 4 (with one color used). Hence, the answer is 2.
妙题啊。
可达性
如果有个 \(C_i \le 1\) 的SubTask的话会更容易想到正解。
我们先不考虑颜色,只考虑是否能找到一种方案把硬币总面值凑成 \(S\) 。
有一种非常朴素的想法是从 \(0\) 到 \(S\) 做可达性dp: $f_{x+V_i} = f_{x+V_i} | f_x $ ,不过因为 \(S \le 10^{18}\) ,显然这是天方夜谭。
可达性dp只有 \(0/1\) 两种状态,非常浪费;发现 \(V_i\) 的值域很小,这启示我们将 \(V_i\) 作为状态减少有效状态数。但究竟如何设置呢?
这里是最巧妙的地方。不失一般性,设 \(V_1 = \min V_i\) 。我们尝试把 \(V_1\) 孤立出来考虑。 假设保证过程中最终选择的总面额永远不会比 \(S\) 大(换句话说,允许选择负数个硬币),那么只需知道硬币集合 \(V - \{ V_1 \}\) 中是否存在一种方案其总面值模 \(V_i\) 与 \(S\) 同余即可。这样就只需对去掉 \(V_1\) 的硬币集合做 \(1\) 到 \(V_1- 1\) 的可达性dp就好了。
考虑把前面那个假设干掉。之前提到 \(f\) 只有 \(0/1\) 两种状态,明显可以再塞点东西进去。于是令 \(f_x\) 为硬币集合 \(V - \{ V_1 \}\) 中所有总面值模 \(V_1\) 等于 \(x\) 的选择方案中最小的总面值。容易写出状态转移
\]
( \(\%\) 代表取模, \(\mathrm{relax} \ A \ \mathrm{by} \ B\) 即 \(A = \min(A,B)\) )
这样一来,若 \(f_{S \% V_1} \le S\) ,那么 \(S\) 就是可以被组成的。
发现这个dp就是个最短路,形成了一个 \(|V| = V_1, |E| = (n-1) V_1\) 的图。于是 Dijkstra 一下就可以了。不过这个图还有更好的性质。
首先,路径中边的顺序可以任意调换而不影响可达性和最短路,所以我们可以分开考虑每一种边的松弛。而一分开看就非常明朗了,根据数论常识,所有 \(x\) 到 \((x + V_i) \% m\) 的边会在图上形成 \(\gcd(V_i, m)\) 个大小为 \(\frac{V_1}{\gcd({V_i, m})}\) 的环,于是现在我们又可以分别考虑每一个环。只需从环上当前距离值最小的点绕环一圈就可以做到松弛了。于是现在预处理的时间复杂度是 \(O(|E|) = O(nV_1)\) ,比直接 Dijkstra 少了个 \(\log\) 。询问当然是 \(O(1)\) 的。
考虑颜色
把颜色放到dp状态里面去就好了。设 \(f_{x, c}\) ,\(c\) 记录了选取的颜色种类数,其余与前述相同。
比较懒,不写代码了。实在需要可以看官方题解。
参考
这篇题解基本上是官方题解的简化翻译版本
CodeChef-LECOINS Little Elephant and Colored Coins 题解的更多相关文章
- CodeChef:Little Elephant and Colored Coins
类似墨墨的等式 设f[2][j][k]表示a[i].c是否和当前颜色相同,到当前枚举到的颜色为止,颜色数为j,对mnv取模为k的最小数 这是个无限循环背包,用spfa优化 #include<cs ...
- CodeChef - LEMOVIE Little Elephant and Movies
Read problems statements in Mandarin Chineseand Russian. Little Elephant from Zoo of Lviv likes to w ...
- [CF780C]Andryusha and Colored Balloons 题解
前言 完了,完了,咕值要没了,赶紧写题解QAQ. 题意简述 给相邻的三个节点颜色不能相同的树染色所需的最小颜色数. 题解 这道题目很显然可以用深搜. 考虑题目的限制,如果当前搜索到的点为u, 显然u的 ...
- Codechef APRIL14 ANUCBC Cards, bags and coins 背包DP变形
题目大意 有n个数字,选出一个子集,有q个询问,求子集和模m等于0的方案数%1000000009.(n <= 100000,m <= 100,q <= 30) 假设数据很小,我们完全 ...
- Colored Boots题解
题目来自Codeforce 1141Dhttp://codeforces.com/problemset/problem/1141/D 因为是全英文题面,就先简单的阐述一下题面. 首先输入一个数n,然后 ...
- 2018 ACM-ICPC南京区域赛题解
解题过程 开场开A,A题shl看错题意,被制止.然后开始手推A,此时byf看错E题题意,开始上机.推出A的规律后,shl看了E题,发现题意读错.写完A题,忘记判断N=0的情况,WA+1.过了A后,sh ...
- scau 2015寒假训练
并不是很正规的.每个人自愿参与自愿退出,马哥找题(马哥超nice么么哒). 放假第一周与放假结束前一周 2015-01-26 http://acm.hust.edu.cn/vjudge/contest ...
- 【翻译】A Next-Generation Smart Contract and Decentralized Application Platform
原文链接:https://github.com/ethereum/wiki/wiki/White-Paper 当中本聪在2009年1月启动比特币区块链时,他同时向世界引入了两种未经测试的革命性的新概念 ...
- Ethereum White Paper
https://github.com/ethereum/wiki/wiki/White-Paper White Paper EditNew Page James Ray edited this pag ...
随机推荐
- 面试官:看你简历说写精通ThreadLocal,这几道题你都会吗?
问题 和Synchronized的区别 存储在jvm的哪个区域 真的只是当前线程可见吗 会导致内存泄漏么 为什么用Entry数组而不是Entry对象 你学习的开源框架哪些用到了ThreadLocal ...
- Union-Find算法应用
上篇文章很多读者对于 Union-Find 算法的应用表示很感兴趣,这篇文章就拿几道 LeetCode 题目来讲讲这个算法的巧妙用法. 首先,复习一下,Union-Find 算法解决的是图的动态连通性 ...
- [Codeforces 580D]Fizzy Search(FFT)
[Codeforces 580D]Fizzy Search(FFT) 题面 给定母串和模式串,字符集大小为4,给定k,模式串在某个位置匹配当且仅当任意位置模式串的这个字符所对应的母串的位置的左右k个字 ...
- 框架篇:见识一下linux高性能网络IO+Reactor模型
前言 网络I/O,可以理解为网络上的数据流.通常我们会基于socket与远端建立一条TCP或者UDP通道,然后进行读写.单个socket时,使用一个线程即可高效处理:然而如果是10K个socket连接 ...
- 直播平台源码搭建教程:微信小程序中的直播如何去掉水印
直播平台源码搭建教程:微信小程序中的直播如何去掉水印 本文与大家分享一下直播平台源码搭建教程,如何去掉直播视频的水印 var services = require('../../lib/service ...
- 遗传算法(Genetic Algorithm)——基于Java实现
一.遗传算法原理介绍 遗传算法(Genetic Algorithm)是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法.遗传算法是从代表问 ...
- pip升级失败
python -m pip install --upgrade pip失败 解决办法: easy_install pip
- 《Python3反爬虫原理与绕过实战》作者韦世东
可以用(k1,k2)-k1来设置,如果有重复的key,则保留key1,舍弃key2/打印appleMap{1=Apple{id=1,name=苹果1,money=3.25,num=10},2=Appl ...
- 第05组 Alpha冲刺 (3/6)(组长)
.th1 { font-family: 黑体; font-size: 25px; color: rgba(0, 0, 255, 1) } #ka { margin-top: 50px } .aaa11 ...
- Linux 中deb文件选择安装路径
deb文件安装后默认目录在/usr**中如果想指定自定义安装目录 选择自定义目录 sudo dpkg -i --instdir=/to/your/customer/path ***.deb 软连接创建 ...