当前位置: 首页 > news >正文

#847(Div3)E. Vlad and a Pair of Numbers

原题链接:

E. Vlad and a Pair of Numbers

题意:

题目有公式 a⊕b=(a+b)/2=xa ⊕ b = (a + b) / 2 = xab=(a+b)/2=x, 给你的是 xxx,让输出一组满足题目要求的 a,ba,bab,没有就输出−1-11

解题:

首先分析异或的性质,不同为1,相同为0。所以可以把 xxx 给二进制化得到字符串s,在s是1的位置上aaabbb 肯定一个是0,一个是1。不妨假定把所有的1都给 aaa ,然后去分析 (a+b)/2(a + b) / 2(a+b)/2,这就相当于把 a+ba + ba+b 右移一位,所以只要让 aaabbb 在 s 为1的位置的上一个地方变成1就可以了,如果下一个位置的地方也是1的话就无解,输出-1。证明如下:
我们不妨通过 xxx 来反推 a+ba + ba+b,可以得到一个 1 的位置永远都比 xxx 的 1 的位置要往前一位,所以要得到这个二进制数只要在的1的后一位的地方变成1就好了,这里要是不懂得话就找一个数推一下,下面是一个例子。

10进制二进制
x001010100
a001111110
b000101010
a + b010101000

代码:

#include <bits/stdc++.h>using namespace std;#define int long long
typedef long long LL;
const int N = 5e5 + 10, mod = 998244353;void solve()
{int n;cin >> n;int a = 0, b = 0;if (n & 1) cout << -1 << '\n';else {for (int i = 1; i <= 30; i ++ ){if (n >> i & 1) {if (n >> (i - 1) & 1){cout << -1 << '\n';return;}}}for (int i = 1; i <= 30; i ++ ){if (n >> i & 1) {a += 1 << i;a += 1 << (i - 1);b += 1 << (i - 1);}}cout << a << ' ' << b << '\n'; }
}signed main()
{int T = 1;cin >> T;while (T -- ){solve();}return 0;
}
http://www.lryc.cn/news/37322.html

相关文章:

  • 怎么把pdf转换成图片?这个方法你值得拥有
  • go语言使用append向二维数组添加一维数组
  • YOLOv5训练大规模的遥感实例分割数据集 iSAID从切图到数据集制作及训练
  • js学习5(函数)
  • 用Qt画一个仪表盘
  • linux 端口查询命令
  • C语言函数: 字符串函数及模拟实现strtok()、strstr()、strerror()
  • 【学习笔记】人工智能哲学研究:《心智、语言和机器》
  • 设计模式之门面模式(外观模式)
  • MySQL - 多表查询
  • 自定义报表是什么?
  • windows安装docker-小白用【避坑】【伸手党福利】
  • 环形链表相关的练习
  • C++ 提示对话框
  • SprintBoot打包及profile文件配置
  • java面试-java集合
  • Node.js简介
  • 每天学一点之Lambda表达式
  • Raft分布式共识算法学习笔记
  • 中介者模式
  • Kaggle赛题解析:Google手语识别
  • 什么是ChatGPT?
  • 深入理解Zookeeper的ZAB协议
  • opencv-图像几何处理
  • [前端笔记030]vue之hello、数据绑定、MVVM、数据代理、事件处理、计算属性和监视属性
  • 每天学一点之注解、元注解
  • STA环境
  • 嵌入式系统实践 12 ——基于ARM汇编 Keil5 MSP432 P401R开发板
  • 【密码学篇】密码行业标准汇总(GM)
  • 桌面文件删除后没有在回收站原因和恢复方法