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

  • 1N30
  • 1Vi200000 (2 * 10^5)
  • 1Ci10^9
  • 1Q200000 (2 * 10^5)
  • 1S10^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} \ f_{(x+V_i)\% V_1} \ \mathrm{by} \ f_x + V_i
\]

( \(\%\) 代表取模, \(\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 题解的更多相关文章

  1. CodeChef:Little Elephant and Colored Coins

    类似墨墨的等式 设f[2][j][k]表示a[i].c是否和当前颜色相同,到当前枚举到的颜色为止,颜色数为j,对mnv取模为k的最小数 这是个无限循环背包,用spfa优化 #include<cs ...

  2. CodeChef - LEMOVIE Little Elephant and Movies

    Read problems statements in Mandarin Chineseand Russian. Little Elephant from Zoo of Lviv likes to w ...

  3. [CF780C]Andryusha and Colored Balloons 题解

    前言 完了,完了,咕值要没了,赶紧写题解QAQ. 题意简述 给相邻的三个节点颜色不能相同的树染色所需的最小颜色数. 题解 这道题目很显然可以用深搜. 考虑题目的限制,如果当前搜索到的点为u, 显然u的 ...

  4. Codechef APRIL14 ANUCBC Cards, bags and coins 背包DP变形

    题目大意 有n个数字,选出一个子集,有q个询问,求子集和模m等于0的方案数%1000000009.(n <= 100000,m <= 100,q <= 30) 假设数据很小,我们完全 ...

  5. Colored Boots题解

    题目来自Codeforce 1141Dhttp://codeforces.com/problemset/problem/1141/D 因为是全英文题面,就先简单的阐述一下题面. 首先输入一个数n,然后 ...

  6. 2018 ACM-ICPC南京区域赛题解

    解题过程 开场开A,A题shl看错题意,被制止.然后开始手推A,此时byf看错E题题意,开始上机.推出A的规律后,shl看了E题,发现题意读错.写完A题,忘记判断N=0的情况,WA+1.过了A后,sh ...

  7. scau 2015寒假训练

    并不是很正规的.每个人自愿参与自愿退出,马哥找题(马哥超nice么么哒). 放假第一周与放假结束前一周 2015-01-26 http://acm.hust.edu.cn/vjudge/contest ...

  8. 【翻译】A Next-Generation Smart Contract and Decentralized Application Platform

    原文链接:https://github.com/ethereum/wiki/wiki/White-Paper 当中本聪在2009年1月启动比特币区块链时,他同时向世界引入了两种未经测试的革命性的新概念 ...

  9. Ethereum White Paper

    https://github.com/ethereum/wiki/wiki/White-Paper White Paper EditNew Page James Ray edited this pag ...

随机推荐

  1. xlrd、xlwt常用命令

    # -*- coding: utf-8 -*- import xlrd import xlwt from datetime import date,datetime   def read_excel( ...

  2. 【实验课选题详解】用C语言实现万年历

    题目要求 编程实现万年历,要求: 可根据用户输入或系统日期进行初始化,如果用户无输入则显示系统日期所在月份的月历,并突出显示当前日期: 可根据用户输入的日期查询,并显示查询结果所在月份的月历,突出显示 ...

  3. python 学习小记之冒泡排序

    lst =[11,22,44,2,1,5,7,8,3] for i in range(len(lst)):     i = 0     while i < len(lst)-1:         ...

  4. Java入门(5)

    阅读书目:Java入门经典(第7版) 作者:罗格斯·卡登海德 protected变量只能在其所在的类,该类的子类,以及同一个包里的其他类中使用.包是一组用于完成相同目标的相关类. private变量只 ...

  5. java开发就业信息管理系统

    本文实例为大家分享了java就业信息管理平台开发案例,供大家参考,具体内容如下 可查询公司信息,学生信息,班级信息,针对学生就业与否信息的统计,老师和管理员登录后的权限不同等就业信息管理平台想要实现的 ...

  6. Linux 软件安装的三种方式

    Linux 软件安装的三种方式 1.yum ​ 语法格式: ​ yum -y install package.name ​ -y yes # 遇到提示自动输入yes ​ 案例: 安装ifconfig命 ...

  7. 1.流程控制--if

    流程控制--if -*- coding:utf-8 -*- #定义字符编码 1.判断条件if age = input("输入年龄:") #将交互式输入内容赋值给age,默认内容为字 ...

  8. CSS 三栏自适应布局

    CSS布局 这个很基础,方法也很多,要留意的知识点还是有一些. 比如IE6的触发layout  *zoom:1 比如使用浮动后的清除浮动  clear:both 需求的延伸也会有一些: 比如三栏等高 ...

  9. [MIT6.006] 21. Daynamic Programming III: Parenthesization, Edit Distance, Knapsack 动态规划III:括号问题,编辑距离,背包问题

    这节课主要针对字符串/序列上的问题,了解如果使用动态规划进行求解.上节课我们也讲过使用前缀和后缀的概念,他们如下所示: 接下来,我们通过三个问题来深入了解下动态规划使用前缀.后缀和子串怎么去解决括号问 ...

  10. Java基础 之一 基本知识

    Java基础 之一 基本知识 1.数据类型 Java有8种基本数据类型 int.short .long.byte.float.double.char.boolean 先说明以下单位之间的关系 1位 = ...