One department of some software company has nn servers of different specifications. Servers are indexed with consecutive integers from 11 to nn . Suppose that the specifications of the jj -th server may be expressed with a single integer number cjcj of artificial resource units.
In order for production to work, it is needed to deploy two services S1S1 and S2S2 to process incoming requests using the servers of the department. Processing of incoming requests of service SiSi takes xixi resource units.
The described situation happens in an advanced company, that is why each service may be deployed using not only one server, but several servers simultaneously. If service SiSi is deployed using kiki servers, then the load is divided equally between these servers and each server requires only xi/kixi/ki (that may be a fractional number) resource units.
Each server may be left unused at all, or be used for deploying exactly one of the services (but not for two of them simultaneously). The service should not use more resources than the server provides.
Determine if it is possible to deploy both services using the given servers, and if yes, determine which servers should be used for deploying each of the services.
Input
The first line contains three integers nn , x1x1 , x2x2 (2≤n≤3000002≤n≤300000 , 1≤x1,x2≤1091≤x1,x2≤109 ) — the number of servers that the department may use, and resource units requirements for each of the services.
The second line contains nn space-separated integers c1,c2,…,cnc1,c2,…,cn (1≤ci≤1091≤ci≤109 ) — the number of resource units provided by each of the servers.
Output
If it is impossible to deploy both services using the given servers, print the only word "No" (without the quotes).
Otherwise print the word "Yes" (without the quotes).
In the second line print two integers k1k1 and k2k2 (1≤k1,k2≤n1≤k1,k2≤n ) — the number of servers used for each of the services.
In the third line print k1k1 integers, the indices of the servers that will be used for the first service.
In the fourth line print k2k2 integers, the indices of the servers that will be used for the second service.
No index may appear twice among the indices you print in the last two lines. If there are several possible answers, it is allowed to print any of them.
Examples
Input
Copy
6 8 16 3 5 2 9 8 7
Output
Copy
Yes 3 2 1 2 6 5 4
Input
Copy
4 20 32 21 11 11 12
Output
Copy
Yes 1 3 1 2 3 4
Input
Copy
4 11 32 5 5 16 16
Output
Copy
No
Input
Copy
5 12 20 7 8 4 11 9
Output
Copy
No
Note
In the first sample test each of the servers 1, 2 and 6 will will provide 8/3=2.(6)8/3=2.(6) resource units and each of the servers 5, 4 will provide 16/2=816/2=8 resource units.
In the second sample test the first server will provide 2020 resource units and each of the remaining servers will provide 32/3=10.(6)32/3=10.(6) resource units.
先从小到大排序。
1.每个部分不连续不如连续,因为一个部分取决于其最小值,不连续会有浪费,连续一定不会比不连续差
2.两个部分都连续,区间越靠右最小值越大越容易满足题意
 故选最靠右的两个相邻区间。
注意这两个相邻区间哪个x哪个y是不确定的。这个是我看样例发现的,原来觉得大配大,小配小。
附上丑陋无比但能过的代码。
#include<bits/stdc++.h>
using namespace std;
long long n,x,y;
struct Node{
	long long num,idx;
	bool operator <(Node x){return num<x.num;}
}a[300010];
int main()
{
//	freopen("input.in","r",stdin);
	cin>>n>>x>>y;
	for(long long i=1;i<=n;i++)cin>>a[i].num;
	for(long long i=1;i<=n;i++)a[i].idx=i;
	sort(a+1,a+1+n);
	bool flag=0;
	
	long long l=n;
	for(;l>=1;l--)
	{
		if((n-l+1)*a[l].num>=y)break;
	}
	bool ok=1;
	if(!l)
	{
	ok=0;
	}
	long long maxn=l-1;
	for(l--;l>=1;l--)
	{
		if((maxn-l+1)*a[l].num>=x)break;
	}
	if(!l)
	{
		ok=0;
	}
	long long maxn2=l;
	if(ok){
	
	puts("Yes");
	
	
		cout<<maxn-maxn2+1<<" "<<n-maxn<<endl;
		for(long long i=maxn2;i<=maxn;i++)cout<<a[i].idx<<" ";
		puts("");
		for(long long i=maxn+1;i<=n;i++)cout<<a[i].idx<<" ";
		puts("");
	exit(0);
}
	swap(x,y);
	l=n;
	for(;l>=1;l--)
	{
		if((n-l+1)*a[l].num>=y)break;
	}
	ok=1;
	if(!l)
	{
	puts("No");exit(0);
	}
	maxn=l-1;
	for(l--;l>=1;l--)
	{
		if((maxn-l+1)*a[l].num>=x)break;
	}
	if(!l)
	{
		puts("No");exit(0);
	}
	maxn2=l;
		puts("Yes");
	
	
		cout<<n-maxn<<" "<<maxn-maxn2+1<<endl;
		for(long long i=maxn+1;i<=n;i++)cout<<a[i].idx<<" ";
		puts("");
		for(long long i=maxn2;i<=maxn;i++)cout<<a[i].idx<<" ";
		puts("");
		
	return 0;
	
}  

 京公网安备 11010502036488号
京公网安备 11010502036488号