zoukankan      html  css  js  c++  java
  • Codeforces.297C.Splitting the Uniqueness(构造)

    题目链接

    (Description)

    给定一个长为n的序列A,求两个长为n的序列B,C,对任意的i满足B[i]+C[i]=A[i],且B,C序列分别至少有(lfloorfrac{2*n}{3} floor)个元素不同。
    A中元素各不相同,Ai,Bi,Ci均为非负整数。

    (Solution)

    (k=lfloorfrac{n}{3} floor),将B,C序列分成三份。可以先将A进行排序。
    B序列1~k取0~k-1,C序列k+1~2k取k~2k-1,C 2k+1~n取0~k-1;B,C其余部分分别为Ai减去另一确定数组
    这样可以满足C序列条件,对于2k+1~n,Ai递增,Ci应是递减的,这样才能满足Bi是单调的(递增),这样B不会在2k+1~n中出现重复。
    最小值B[2k+1]=A[2k+1]-C[2k+1]>=k+1,即大于任意Bi(i∈[1,k])。
    若Ai是各不相同的,那么一定有解;否则要讨论下。

    (博客园不会表格。。)
    注意k不能单纯地取n/3,在有余数比如5的时候,序列1.2部分元素比3部分少,可能在3部分会有重复,在n比较大的时候这重复的两个元素就很致命了。

    /*
    		 1~k		   k+1~2k          2k+1~n
    Bi	  0,1,2,...,k-1		Ai-Ci		     Ai-Ci
    Ci		Ai-Bi		k,k+1,...,2k-1	k-1,...,2,1,0
    */
    #include <cstdio>
    #include <cctype>
    #include <algorithm>
    #define gc() getchar()
    #define mp std::make_pair
    const int N=1e5+5;
    
    int n;
    std::pair<int,int> A[N];
    struct Answer
    {
    	int id,b,c;
    	bool operator <(const Answer &x)const {return id<x.id;}
    }ans[N];
    
    inline int read()
    {
    	int now=0,f=1;register char c=gc();
    	for(;!isdigit(c);c=gc()) if(c=='-') f=-1;
    	for(;isdigit(c);now=now*10+c-'0',c=gc());
    	return now*f;
    }
    
    int main()
    {
    	n=read();
    	for(int i=1; i<=n; ++i) A[i]=mp(read(),i);
    	std::sort(A+1,A+1+n);
    	int k=(n+2)/3;
    	for(int i=1; i<=k; ++i) ans[i].b=i-1, ans[i].c=A[i].first-i+1, ans[i].id=A[i].second;
    	for(int i=k+1; i<=k<<1; ++i) ans[i].c=i-1, ans[i].b=A[i].first-i+1, ans[i].id=A[i].second;
    	for(int i=k<<1|1; i<=n; ++i) ans[i].c=n-i, ans[i].b=A[i].first-n+i, ans[i].id=A[i].second;
    	std::sort(ans+1,ans+1+n);
    	puts("YES");
    	for(int i=1; i<n; ++i) printf("%d ",ans[i].b);
    	printf("%d
    ",ans[n].b);
    	for(int i=1; i<n; ++i) printf("%d ",ans[i].c);
    	printf("%d",ans[n].c);
    
    	return 0;
    }
    
  • 相关阅读:
    范仁义css3课程---7、文本样式2
    android图片缓存框架Android-Universal-Image-Loader(二)
    Android 开源框架Universal-Image-Loader完全解析(三)---源代码解读
    憨人 音译
    Android 开源框架Universal-Image-Loader完全解析(一)--- 基本介绍及使用
    Android 开源框架Universal-Image-Loader完全解析(二)--- 图片缓存策略详解
    Android开发
    87狂热
    迟志强
    翟惠民
  • 原文地址:https://www.cnblogs.com/SovietPower/p/8457095.html
Copyright © 2011-2022 走看看