← Home
write a go solution for Description:
Once upon a time Algoland and Berland were a single country, but those times are long gone. Now they are two different countries, but their cities are scattered on a common territory.

All cities are represented as points on the Cartesian plane. Algoland consists of a cities numbered from 1 to a. The coordinates of the i-th Algoland city are a pair of integer numbers (xa_i,ya_i). Similarly, Berland consists of b cities numbered from 1 to b. The coordinates of the j-th Berland city are a pair of integer numbers (xb_j,yb_j). No three of the a+b mentioned cities lie on a single straight line.

As the first step to unite the countries, Berland decided to build several bidirectional freeways. Each freeway is going to be a line segment that starts in a Berland city and ends in an Algoland city. Freeways can't intersect with each other at any point except freeway's start or end. Moreover, the freeways have to connect all a+b cities. Here, connectivity means that one can get from any of the specified a+b cities to any other of the a+b cities using freeways. Note that all freeways are bidirectional, which means that one can drive on each of them in both directions.

Mayor of each of the b Berland cities allocated a budget to build the freeways that start from this city. Thus, you are given the numbers r_1,r_2,...,r_b, where r_j is the number of freeways that are going to start in the j-th Berland city. The total allocated budget is very tight and only covers building the minimal necessary set of freeways. In other words, r_1+r_2+...+r_b=a+b-1.

Help Berland to build the freeways so that:

- each freeway is a line segment connecting a Berland city and an Algoland city,
- no freeways intersect with each other except for the freeway's start or end,
- freeways connect all a+b cities (all freeways are bidirectional),
- there are r_j freeways that start from the j-th Berland city.

Input Format:
Input contains one or several test cases. The first input line contains a single integer number t (1<=t<=3000) — number of test cases. Then, t test cases follow. Solve test cases separately, test cases are completely independent and do not affect each other.

Each test case starts with a line containing space-separated integers a and b (1<=a,b<=3000) — numbers of Algoland cities and number of Berland cities correspondingly.

The next line contains b space-separated integers r_1,r_2,...,r_b (1<=r_b<=a) where r_j is the number of freeways, that should start in the j-th Berland city. It is guaranteed that r_1+r_2+...+r_b=a+b-1.

The next a lines contain coordinates of the Algoland cities — pairs of space-separated integers xa_i,ya_i (-10000<=xa_i,ya_i<=10000). The next b lines contain coordinates of the Berland cities — pairs of space-separated integers xb_i,yb_i (-10000<=xb_i,yb_i<=10000). All cities are located at distinct points, no three of the a+b cities lie on a single straight line.

Sum of values a across all test cases doesn't exceed 3000. Sum of values b across all test cases doesn't exceed 3000.

Output Format:
For each of the t test cases, first print "YES" if there is an answer or "NO" otherwise.

If there is an answer, print the freeway building plan in the next a+b-1 lines. Each line of the plan should contain two space-separated integers j and i which means that a freeway from the j-th Berland city to the i-th Algoland city should be built. If there are multiple solutions, print any.

Note:
None. Output only the code with no comments, explanation, or additional text.