zoukankan      html  css  js  c++  java
  • D. Ehab the Xorcist

    D. Ehab the Xorcist

    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Given 2 integers uu and vv, find the shortest array such that bitwise-xor of its elements is uu, and the sum of its elements is vv.

    Input

    The only line contains 2 integers uu and v(0u,v1018)(0≤u,v≤1018).

    Output

    If there's no array that satisfies the condition, print "-1". Otherwise:

    The first line should contain one integer, nn, representing the length of the desired array. The next line should contain npositive integers, the array itself. If there are multiple possible answers, print any.

    Examples
    input
    Copy
    2 4
    
    output
    Copy
    2
    3 1
    input
    Copy
    1 3
    
    output
    Copy
    3
    1 1 1
    input
    Copy
    8 5
    
    output
    Copy
    -1
    input
    Copy
    0 0
    
    output
    Copy
    0
    Note

    In the first sample, 31=23⊕1=2 and 3+1=43+1=4. There is no valid array of smaller length.

    Notice that in the fourth sample the array is empty.

    1.一个序列的异或和一定小于等于数值和。

    2.一个序列的数值和和异或和奇偶性相同。

    a+b=(ab)+2(ab)

    #include "stdafx.h"
    #include <iostream>
    #include <vector>
    #include <algorithm>
    #include <string>
    #include <set>
    #include <queue>
    #include <map>
    #include <sstream>
    #include <cstdio>
    #include <cstring>
    #include <numeric>
    #include <cmath>
    #include <iomanip>
    #include <deque>
    #include <bitset>
    //#include <unordered_set>
    //#include <unordered_map>
    //#include <bits/stdc++.h>
    //#include <xfunctional>
    #define ll  long long
    #define PII  pair<int, int>
    using namespace std;
    int dir[5][2] = { { 0,1 } ,{ 0,-1 },{ 1,0 },{ -1,0 } ,{ 0,0 } };
    const long long INF = 0x7f7f7f7f7f7f7f7f;
    const int inf = 0x3f3f3f3f;
    const double pi = 3.14159265358979;
    const int mod = 1e9 + 7;
    const int maxn = 2005;
    //if(x<0 || x>=r || y<0 || y>=c)
    //1000000000000000000
    
    inline ll read()
    {
        ll x = 0; bool f = true; char c = getchar();
        while (c < '0' || c > '9') { if (c == '-') f = false; c = getchar(); }
        while (c >= '0' && c <= '9') x = (x << 1) + (x << 3) + (c ^ 48), c = getchar();
        return f ? x : -x;
    }
    
    int main() 
    {
        ll u, v;
        cin >> u >> v;
        ll d = v - u;
        if (d < 0 || (d % 2))
        {
            cout << -1 << endl;
            return 0;
        }
        if (!d)
        {
            if (!u)
                cout << 0 << endl;
            else
            {
                cout << 1 << endl;
                cout << u << endl;
            }
        }
        else
        {
            ll h = d >> 1;
            if ((h&u) == 0)
            {
                cout << 2 << endl;
                cout << h << " " << (h^u) << endl;
            }
            else
            {
                cout << 3 << endl;
                cout << h << " " << h << " " << u << endl;
            }
        }
        return 0;
    }
  • 相关阅读:
    php设计模式注册表模式
    zend studio
    java中模仿C++实现条件编译
    javascript去掉字符串空格——转
    领域模型谈实体对象和值对象
    面向对象语言的多分派、单分派、双重分派
    Java中Split函数的用法技巧
    web页面导出到Excel乱码解决
    在web项目中如何使用rdlc报表
    ASP.NET控件10个最有用的属性详解
  • 原文地址:https://www.cnblogs.com/dealer/p/12679694.html
Copyright © 2011-2022 走看看