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;
}
相关推荐
努力努力再努力wz3 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
J2虾虾3 小时前
C 语言 void 完全用法
c语言·开发语言
wu_ye_m4 小时前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习
J2虾虾7 小时前
C语言 typedef 用法
c语言·数据结构·算法
WL学习笔记8 小时前
顺序表详解
c语言·数据结构
c++之路8 小时前
CMake 系列教程(一):CMake 基础知识
c语言·开发语言·c++
我还记得那天8 小时前
C语言随机数生成机制与猜数字游戏实现
c语言·开发语言·游戏
万法若空9 小时前
C/C++基本类型表示范围
c语言·开发语言·c++
J2虾虾11 小时前
C 语言 sizeof 完全用法指南
c语言·数据结构·算法
xxwxx__11 小时前
51单片机定时器/计数器中断详解(T0和T1)——从入门到精通
c语言·单片机·嵌入式硬件·51单片机