A. Helmets in Night Light

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 的花费进行通知。

cpp 复制代码
#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;
}
相关推荐
LDR00614 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
Luminous.14 天前
C语言--day30
c语言·开发语言
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
謓泽14 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
不会C语言的男孩14 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
2601_9516438814 天前
C语言长文整理,关键字和数据类型
c语言·数据类型·关键字·嵌入式开发·格式化输出
m0_5474866615 天前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
✎ ﹏梦醒͜ღ҉繁华落℘15 天前
编程基础 --高内聚,低耦合
c语言·单片机
QK_0015 天前
C语言 static 关键字三大作用
c语言·开发语言
隔窗听雨眠15 天前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化