贪心,每次遇到一个满水的湖要下暴雨的时候,就往前找之前最后一次满水之后的第一个没有下雨的且没有被用掉天day1。
因为如果不选这day1,那么之后的湖不一定能选上这一天。如果这一天后面还有没有下雨的天day2的话,选后面的,会使得day1到day2之间满水的湖选择减少。
#include<bits/stdc++.h>
#define PB push_back
#define MP make_pair
#define fi first
#define second
#define FOR(i,s,e) for(int i = s; i < e; i++)
using namespace std; const int maxn = 1e6+; int lastTime[maxn]; int drink[maxn];
set<int> unUsedNoRainDays;
vector<int> NoRainDays; int main()
{
//freopen("in.txt","r",stdin);
set<int> &s = unUsedNoRainDays;
vector<int> &v = NoRainDays;
int *d = drink;
int *lT = lastTime;
int T; scanf("%d",&T);
for(int k = ; k <= T; k++){
int n,m; scanf("%d%d",&n,&m);
memset(lastTime+,,sizeof(int)*n); s.clear(); v.clear();
bool fail = false;
for(int i = ; i <= m; i++) {
int t;
scanf("%d",&t);
if(t){
set<int>::iterator it = s.lower_bound(lT[t]);
if(it != s.end()){
d[*it] = t;
lT[t] = i;
s.erase(it);
}else {
for(; i < m; i++) scanf("%d",&t);
fail = true;
}
}else {
v.PB(i);
d[i] = ;
s.insert(i);
}
}
if(fail){
puts("NO");
}else {
printf("YES"); printf("\n%d",d[v[]]);
for(int i = ; i < v.size(); i++){
printf(" %d",d[v[i]]);
}
putchar('\n');
}
}
return ;
}