c题:
思路很简单。
由题意可知,奇数的集合有k-p个,偶数的几何有p个。
那么我们先选择k-p-1个奇数,每一个奇数是一个集合。
然后我们再选择p个偶数,每一个偶数是一个集合,如果偶数的个数不足,那么就用两个奇数去补。
然后我们再把剩下的所有的数放在一个集合里。
by rowanhao, contest: codeforces round #251 (div. 2), problem: (c) devu and partitioning of the array, accepted, # #include#include#include#include#include#includeusing namespace std;#define ll __int64#define maxn 330000vectorvec;int a[maxn];int vis[maxn];int main(){ int n,k,p; while(~scanf(%d%d%d,&n,&k,&p)) { int sum=0; int q=k-p; int l,r; l=r=0; for(int i=1;i=p*2&&l%2==0) { l=p; cout1) { vis[i]=1; l--; printf(1 %d\n,a[i]); } } vec.clear(); for(int i=1;i1&&vec.size()==2) { printf(2 %d %d\n,vec[0],vec[1]); vec.clear(); l--; } } if(vec.size()==0)continue; printf(%d,vec.size()); for(int i=0;id题:
思路也挺简单的。
由题意可知,我们需要把a数组的所有的数都变的大于等于x。b数组里的所有的数都小于等于x。
x是a数组和b数组中的某一个数。
那么我们枚举x,然后二分查找。
#include#include#include#include#includeusing namespace std;#define ll __int64#define maxn 220100double num[maxn];vectorvec;ll a[maxn];ll b[maxn];ll sa[maxn];ll sb[maxn];ll n,m;ll dos(ll x){ ll sum=0; ll l,r,mid; l=1;r=n+1;mid=(l+r)/2; while(l=x)r=mid; else l=mid+1; mid=(l+r)/2; } sum+=(mid-1)*x-sa[mid-1]; l=1;r=m+1;mid=(l+r)/2; while(l=x)r=mid; else l=mid+1; mid=(l+r)/2; } sum+=sb[mid]-(m-mid+1)*x; return sum;}int main(){ while(~scanf(%i64d%i64d,&n,&m)) { for(ll i=1;i=1;i--)sb[i]=sb[i+1]+b[i]; ll minn=-1; for(ll i=0;i