data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" /**//*
给出A,B ,求X,Y,使得 A = X + Y, B = X xor Y。要使得X最小,若不存在输出-1
0<=A,B<2^64
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
看了解题报告的,挺巧的,切入点是:“使得X最小” -----------------OMG
若(X,Y)是满足条件的一对数,则检查每一位
若Xi = 1, Yi = 0 则可交换这两位,上面的等式还是成立,但是X减小了,Y增大了
完成上面的操作后,(X,Y)的情况只能是(0,1),(0,0),(1,1)
则有 Y - X = X xor Y = B -------------------OMG
所以 X = (A-B)/2 , Y = (A+B)/2
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
巧丫 ..
*/
#include<iostream>
#include<cstring>
#include<map>
#include<algorithm>
#include<stack>
#include<queue>
#include<cmath>
#include<string>
#include<cstdlib>
#include<vector>
#include<cstdio>
#include<set>
#include<list>
#include<numeric>
#include<cassert>
#include<ctime>
#include<bitset>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
using namespace std;
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="" data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="" {
#ifndef ONLINE_JUDGE
freopen("in","r",stdin);
#endif
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" for (unsigned long long A, B; cin>>A>>B; ) {
//A = X + Y, B = X ^ Y . X is minimal
//swap(xi,yi) if xi = 1 and yi = 0, the equalities above mantian.
//after all the swaping, we can find that
//(xi,yi) can only be (0,1) , (0,0), (1,1)
//so X ^ Y = Y - X = B
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" if (((A&1) ^ (B&1)) || A < B) {
cout << -1 << endl;
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="" } else {
cout << (A-B)/2 <<" "<< (A+B)/2<<endl;
}
}
return 0;
}
|