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 ... 
随机推荐
- codefroces中的病毒,这题有很深的trick,你能解开吗?
			大家好,欢迎阅读周末codeforces专题. 我们今天选择的问题是contest 1419的C题,目前有接近8000的人通过了本题.今天这题的难度不大,但是真的很考验思维,一不小心就会踩中陷阱,我个 ... 
- D. New Year Santa Network 解析(思維、DFS、組合、樹狀DP)
			Codeforce 500 D. New Year Santa Network 解析(思維.DFS.組合.樹狀DP) 今天我們來看看CF500D 題目連結 題目 給你一棵有邊權的樹,求現在隨機取\(3 ... 
- 栈的C++实现
			数据结构c++实现系列第一篇. 话不多说,直接上代码. sichstack.h (头文件) 1 #pragma once 2 #include<string> 3 4 namespace ... 
- python 作业 用python实现 mysql查询结果导出带列名
			1 import pandas as pd 2 import numpy as np 3 import matplotlib as mpl 4 import matplotlib.pyplot as ... 
- BP神经网络算法程序实现鸢尾花(iris)数据集分类
			作者有话说 最近学习了一下BP神经网络,写篇随笔记录一下得到的一些结果和代码,该随笔会比较简略,对一些简单的细节不加以说明. 目录 BP算法简要推导 应用实例 PYTHON代码 BP算法简要推导 该部 ... 
- symfony3.4 配置高效的邮箱swiftmailer插件
			网站经常需要邮件发送,symfony里面swiftmailerBundle是一个非常并且稳定的发送邮件的第三方插件. 我们来看一下symfony里面的邮件怎么配置. 第一步我们先下载bundle: c ... 
- Linux使用tmux
			Tmux功能: 提供了强劲的.易于使用的命令行界面.可横向和纵向分割窗口.窗格可以自由移动和调整大小,或直接利用四个预设布局之一.支持 UTF-8 编码及 256 色终端.可在多个缓冲区进行复制和粘贴 ... 
- django 框架模型之models常用的Field
			1. django 模型models 常用字段 1.models.AutoField 自增列 = int(11) 如果没有的话,默认会生成一个名称为 id 的列 如果要显式的自定义一 ... 
- ELK搭建以及运行和ElasticStarch的详细使用(7.X版本之上)
			ELK初体验 1.官网 https://www.elastic.co/cn/downloads/elasticsearch 2.需要安装JDK ElasticSearch 是一 ... 
- Java入门(4)
			阅读书目:Java入门经典(第7版) 作者:罗格斯·卡登海德 面向对象编程(OOP)将程序视为对象的集合,确定程序要完成的任务,然后将这些任务指派给最适合完成它们的对象.换言之,计算机程序是一组对象, ... 
