AT_qupc2018_i Buffalo
题目描述
有 $N$ 个容器,第 $i$ 个容器最多能盛 $A_i$ 升的水。
小 U 需要从中选择任意两个容器,通过以下操作反复进行,最终使得这两个容器中的水总量达到正好 $K$ 升。可以进行的操作包括:
- 操作 1:将一个容器灌满。
- 操作 2:从容器 $X$ 中往容器 $Y$ 中倒水,直到容器 $Y$ 装满或者容器 $X$ 空为止。
- 操作 3:将一个容器中的水全部倒掉。
请计算一共有多少对容器,可以通过以上操作让它们恰好装 $K$ 升的水。
注意,开始时所有容器都是空的,可以选择不用其中一个容器。
输入格式
输入通过标准输入给出:
> $N$ $K$ $A_1$ $A_2$ $\ldots$ $A_N$
输出格式
输出一个整数,表示符合条件的容器组合的数量。
说明/提示
- $2 \leq N \leq 3 \times 10^5$
- $1 \leq K \leq 2 \times 10^6$
- $1 \leq A_i \leq 10^6$
- 所有输入均为整数
### 样例解释 1
假设选第 1 个和第 2 个容器,我们可以这样操作来获得 3 升水:
- 将第 2 个容器灌满。
- 从第 2 个容器中往第 1 个容器倒水,直到第 1 个装满。
- 把第 1 个容器中的水全部倒掉。
### 样例解释 2
在所有可能的容器组合中,我们都能获得 11 升水。
**本翻译由 AI 自动生成**