CF1779D.Boris and His Amazing Haircut
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Boris thinks that chess is a tedious game. So he left his tournament early and went to a barber shop as his hair was a bit messy.
His current hair can be described by an array a1,a2,…,an , where ai is the height of the hair standing at position i . His desired haircut can be described by an array b1,b2,…,bn in a similar fashion.
The barber has m razors. Each has its own size and can be used at most once. In one operation, he chooses a razor and cuts a segment of Boris's hair. More formally, an operation is:
- Choose any razor which hasn't been used before, let its size be x ;
- Choose a segment [l,r] ( 1≤l≤r≤n );
- Set ai:=min(ai,x) for each l≤i≤r ;
Notice that some razors might have equal sizes — the barber can choose some size x only as many times as the number of razors with size x .
He may perform as many operations as he wants, as long as any razor is used at most once and ai=bi for each 1≤i≤n at the end. He does not have to use all razors.
Can you determine whether the barber can give Boris his desired haircut?
输入格式
Each test contains multiple test cases. The first line contains the number of test cases t ( 1≤t≤20000 ). The description of the test cases follows.
The first line of each test case contains a positive integer n ( 3≤n≤2⋅105 ) — the length of arrays a and b .
The second line of each test case contains n positive integers a1,a2,…,an ( 1≤ai≤109 ) — Boris's current hair.
The third line of each test case contains n positive integers b1,b2,…,bn ( 1≤bi≤109 ) — Boris's desired hair.
The fourth line of each test case contains a positive integer m ( 1≤m≤2⋅105 ) — the number of razors.
The fifth line of each test case contains m positive integers x1,x2,…,xm ( 1≤xi≤109 ) — the sizes of the razors.
It is guaranteed that the sum of n and the sum of m over all test cases do not exceed 2⋅105 .
输出格式
For each test case, print "YES" if the barber can cut Boris's hair as desired. Otherwise, print "NO".
You can output the answer in any case (upper or lower). For example, the strings "yEs", "yes", "Yes", and "YES" will be recognized as positive responses.
输入输出样例
输入#1
7 3 3 3 3 2 1 2 2 1 2 6 3 4 4 6 3 4 3 1 2 3 2 3 3 3 2 3 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 10 1 2 3 4 5 6 7 8 9 10 3 1 1 1 1 1 2 12 4 2 4 3 1 5 6 3 5 6 2 1 13 7 9 4 5 3 3 3 6 8 10 3 2 5 5 3 1 5 3 2 2 5 8 5 1 1 5 8 1 5 3 5 4 2 3 1 13 7 9 4 5 3 3 3 6 8 10 3 2 5 5 3 1 5 3 2 2 5 8 5 1 1 5 7 1 5 3 4 2 3 1 3 19747843 2736467 938578397 2039844 2039844 2039844 1 2039844
输出#1
YES NO YES NO YES NO YES
说明/提示
In the first test case, Boris's hair is initially [3,3,3] . Let us describe a sequence of 2 operations the barber can perform:
- The barber uses the razor with size 1 on the segment [2,2] ; hence Boris's hair becomes [3,1,3] .
- The barber uses the razor with size 2 on the segment [1,3] ; hence Boris's hair becomes [2,1,2] which is the desired haircut.
In the third test case, no operation has to be done since Boris's hair is already as desired.
In the fourth test case, no cuts will be able to increase the third element in [1,1,1] in a way that the array becomes [1,1,2] .