Problem11061--[GESP六级] [202409]算法学习

11061: [GESP六级] [202409]算法学习

[Creator : ]
Time Limit : 1.000 sec  Memory Limit : 512 MiB

Description

小杨计划学习 $m$ 种算法,为此他找了 $n$ 道题目来帮助自己学习,每道题目至多学习一次。

小杨对于 $m$ 种算法的初始掌握程度均为 $0$。第 $i$ 道题目有对应的知识点 $a_i$,即学习第 $i$ 道题目可以令小杨对第 $a_i$ 种算法的掌握程度提高 $b_i$。小杨的学习目标是对 $m$ 种算法的掌握程度均至少为 $k$。

小杨认为连续学习两道相同知识点的题目是不好的,小杨想请你编写程序帮他计算出他最少需要学习多少道题目才能使得他在完成学习目标的同时避免连续学习两道相同知识点的题目。

Input

第一行三个正整数 $m,n,k$,代表算法种类数,题目数和目标掌握程度。

第二行 $n$ 个正整数 $a_1,a_2,\cdots,a_n$,代表每道题目的知识点。

第三行 $n$ 个正整数 $b_1,b_2,\cdots,b_n$,代表每道题目提升的掌握程度。

Output

输出一个整数,代表小杨最少需要学习题目的数量,如果不存在满足条件的方案,输出 -1。

Constraints

保证 $1\leq m,n \leq 10^5,\ 1 \leq b_i,k \leq 10^5,\ 1 \leq a_i \leq m$。

Sample 1 Input

3 5 10
1 1 2 3 3
9 1 10 10 1

Sample 1 Output

4
一种最优学习顺序为第一道题,第三道题,第四道题,第二道题。

Sample 2 Input

2 4 10
1 1 1 2
1 2 7 10

Sample 2 Output

-1

Source/Category