zoukankan      html  css  js  c++  java
  • codeforces405D

    Toy Sum

     CodeForces - 405D 

    Little Chris is very keen on his toy blocks. His teacher, however, wants Chris to solve more problems, so he decided to play a trick on Chris.

    There are exactly s blocks in Chris's set, each block has a unique number from 1 to s. Chris's teacher picks a subset of blocks X and keeps it to himself. He will give them back only if Chris can pick such a non-empty subset Y from the remaining blocks, that the equality holds:

    "Are you kidding me?", asks Chris.

    For example, consider a case where s = 8 and Chris's teacher took the blocks with numbers 1, 4 and 5. One way for Chris to choose a set is to pick the blocks with numbers 3 and 6, see figure. Then the required sums would be equal: (1 - 1) + (4 - 1) + (5 - 1) = (8 - 3) + (8 - 6) = 7.

    However, now Chris has exactly s = 106 blocks. Given the set X of blocks his teacher chooses, help Chris to find the required set Y!

    Input

    The first line of input contains a single integer n (1 ≤ n ≤ 5·105), the number of blocks in the set X. The next line contains n distinct space-separated integers x1x2..., xn (1 ≤ xi ≤ 106), the numbers of the blocks in X.

    Note: since the size of the input and output could be very large, don't use slow output techniques in your language. For example, do not use input and output streams (cin, cout) in C++.

    Output

    In the first line of output print a single integer m (1 ≤ m ≤ 106 - n), the number of blocks in the set Y. In the next line output m distinct space-separated integers y1y2..., ym (1 ≤ yi ≤ 106), such that the required equality holds. The sets X and Yshould not intersect, i.e. xi ≠ yj for all ij (1 ≤ i ≤ n1 ≤ j ≤ m). It is guaranteed that at least one solution always exists. If there are multiple solutions, output any of them.

    Examples

    Input
    3
    1 4 5
    Output
    2
    999993 1000000
    Input
    1
    1
    Output
    1
    1000000

    sol:显然可以从两边往中间做,如果一边有就弄另一边,两边都有就弄一对新的即可

    #include <bits/stdc++.h>
    using namespace std;
    typedef int ll;
    inline ll read()
    {
        ll s=0; bool f=0; char ch=' ';
        while(!isdigit(ch)) {f|=(ch=='-'); ch=getchar();}
        while(isdigit(ch)) {s=(s<<3)+(s<<1)+(ch^48); ch=getchar();}
        return (f)?(-s):(s);
    }
    #define R(x) x=read()
    inline void write(ll x)
    {
        if(x<0) {putchar('-'); x=-x;}
        if(x<10) {putchar(x+'0'); return;}
        write(x/10); putchar((x%10)+'0');
    }
    #define W(x) write(x),putchar(' ')
    #define Wl(x) write(x),putchar('
    ')
    const int N=1000005;
    int S=1000000,n,m=0,a[N],b[N];
    bool Bo[N];
    int main()
    {
        int i;
        R(n);
        for(i=1;i<=n;i++) Bo[a[i]=read()]=1;
        int up=S>>1,cnt=0;
        for(i=1;i<=up;i++)
        {
            int o1=i,o2=S-i+1;
            if((Bo[o1])&&(!Bo[o2]))
            {
                b[++m]=o2; Bo[o2]=1;
            }
            else if((!Bo[o1])&&(Bo[o2]))
            {
                b[++m]=o1; Bo[o1]=1;
            }
            else if(Bo[o1]&&Bo[o2]) cnt++;
        }
        for(i=1;i<=up&&cnt;i++)
        {
            if(!Bo[i])
            {
                b[++m]=i; b[++m]=S-i+1; cnt--;
            }
        }
        sort(b+1,b+m+1);
        Wl(m);
        for(i=1;i<=m;i++) W(b[i]);
        return 0;
    }
    View Code
     
  • 相关阅读:
    2019.10.31 答辩回来后;
    2019.10.22
    2019.10.21 上周总结+今天
    2019.10.20 没有人可以阻挡自己努力,男朋友也不可以。少情感,多学习;;多夸夸他肯定他
    2019.10.19 干什么? 不要纠结了于下手什么了 趁还年轻 去做吧!!
    2019.10.16 每天问自己 三遍 或者更多:我收获了什么?我收获了什么?我收获了什么???
    Java 错误:Constructor call must be the first statement in a constructor
    2019.10.14 解决讨好型人格;时间管理划分等级+设定时间上限
    2019.10.14 今天看到的业务大佬的肺腑之言
    放几张吴悠校园行
  • 原文地址:https://www.cnblogs.com/gaojunonly1/p/11219023.html
Copyright © 2011-2022 走看看