time limit per test

1 second

memory limit per test

256 megabytes

Pak Chanek is the chief of a village named Khuntien. On one night filled with lights, Pak Chanek has a sudden and important announcement that needs to be notified to all of the n residents in Khuntien.

First, Pak Chanek shares the announcement directly to one or more residents with a cost of p for each person. After that, the residents can share the announcement to other residents using a magical helmet-shaped device. However, there is a cost for using the helmet-shaped device. For each i, if the i-th resident has got the announcement at least once (either directly from Pak Chanek or from another resident), he/she can share the announcement to at most ai other residents with a cost of bi for each share.

If Pak Chanek can also control how the residents share the announcement to other residents, what is the minimum cost for Pak Chanek to notify all n residents of Khuntien about the announcement?

Input

Each test contains multiple test cases. The first line contains an integer t (1≤t≤104) — the number of test cases. The following lines contain the description of each test case.

The first line contains two integers n and p (1≤n≤105; 1≤p≤105) — the number of residents and the cost for Pak Chanek to share the announcement directly to one resident.

The second line contains n integers a1,a2,a3,…,an (1≤ai≤105) — the maximum number of residents that each resident can share the announcement to.

The third line contains n integers b1,b2,b3,…,bn (1≤bi≤105) — the cost for each resident to share the announcement to one other resident.

It is guaranteed that the sum of n over all test cases does not exceed 105.

Output

For each test case, output a line containing an integer representing the minimum cost to notify all n residents of Khuntien about the announcement.

Example

Input

Copy


3

6 3

2 3 2 1 1 3

4 3 2 6 3 6

1 100000

100000

1

4 94

1 4 2 3

103 96 86 57

Output

Copy

16
100000
265

Note

In the first test case, the following is a possible optimal strategy:

  1. Pak Chanek shares the announcement directly to the 3-rd, 5-th, and 6-th resident. This requires a cost of p+p+p=3+3+3=9.
  2. The 3-rd resident shares the announcement to the 1-st and 2-nd resident. This requires a cost of b3+b3=2+2=4.
  3. The 2-nd resident shares the announcement to the 4-th resident. This requires a cost of b2=3.

The total cost is 9+4+3=16. It can be shown that there is no other strategy with a smaller cost.

解题说明:此题采用贪心算法,可以按花费 进行排序一下,如果b<p 就让他用 b 的花费告诉别人,剩下的人一开始用 p 的花费进行通知。

#include <bits/stdc++.h>
#include<algorithm>
#include<iostream>
#include<vector>

using namespace std;
int main() {
	int t;
	cin >> t;
	while (t--) {
		int64_t i, n, p, c = 1, ans;
		cin >> n >> p;
		ans = p;
		vector<pair<int64_t, int64_t>> l(n);
		for (i = 0; i < n; i++)
		{
			cin >> l[i].second;
		}
		for (i = 0; i < n; i++)
		{
			cin >> l[i].first;
		}
		sort(l.begin(), l.end());
		for (auto [f, s] : l) 
		{
			if (f > p)
			{
				break;
			}
			ans += f * min(s, n - c);
			c += min(s, n - c);
		}
		ans += (n - c) * p;
		cout << ans << endl;
	}
	return 0;
}

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐