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

C . Serval and The Formula【Codeforces Round 1011 (Div. 2)】

C.Serval and The Formula

在这里插入图片描述

思路:

这场打的纯唐,导致掉大分了,主要就是卡这个题了。
一直在想怎么位运算,但是忽略了最基础的观察和构造方法,div2前三题的思维题一般都是:Attention is all you need.

注意到 x + y = ( x ⊕ y ) + 2 ( x & y ) x + y = (x \oplus y) + 2(x \& y) x+y=(xy)+2(x&y) ,说明想要满足题目要求的形式,就得让 x + k x+k x+k y + k y+k y+k的二进制在同一位上不能同时为1
可以证明x==y时是无解的。
又注意到可以把 m a x ( x , y ) max({x,y}) max(x,y) 变成 1000000 这样的形式,那么答案就很简单了:
k = 2 n − m a x ( x , y ) k=2^n-max(x,y) k=2nmax(x,y),n足够大就行。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define endl '\n'
#define int long long
#define pb push_back
#define pii pair<int, int>
#define FU(i, a, b) for (int i = (a); i <= (b); ++i)
#define FD(i, a, b) for (int i = (a); i >= (b); --i)
const int MOD = 1e9 + 7;
const int INF = 0x3f3f3f3f;
int zb(int n) { return log2f(n & -n); }
void solve() {
    int x, y;
    cin >> x >> y;
    if(x==y ){cout<<"-1\n";return;}
    if (y > x)
        swap(x, y);
    int k = (1<<(__lg(x)+1))-x;
    cout << k<<endl;
}

signed main() {
    cin.tie(0)->ios::sync_with_stdio(0);
    int T = 1;
    cin >> T;
    while (T--) {
        solve();
    }
    return 0;
}

相关文章:

  • 社群经济4.0时代:开源链动模式与AI技术驱动的电商生态重构
  • DockerFile制作镜像(Dockerfile Creates an Image)
  • 在Spring Boot中,可以通过实现一些特定的接口来拓展Starter
  • 心法利器[132] | 大模型系统性能优化trick
  • 5.2 位运算专题:LeetCode 268. 丢失的数字
  • Ubuntu 系统部署 Ollama + DeepSeek + Docker + Ragflow
  • 企业微信实现“关联外部选项“、“审批控件中的外部选项“
  • Four.meme是什么,一篇文章读懂
  • 信息的度量
  • 安宝特方案丨安宝特AR远程医疗方案如何重塑智慧医疗服务体系?
  • Jetson Orin NX使用 Ollama 本地部署 deepseek
  • 2025年上软考——【系统架构设计师】考前60天冲刺学习指南!!!
  • 内网渗透-端口映射
  • ngrep :网络嗅探的利器
  • 【RAG综述系列】之 RAG 相关背景和基本原理
  • 乐道突围特斯拉
  • 六十天前端强化训练之第三十天之深入解析Vue3电商项目:TechStore全栈实践(文结尾附有源代码)
  • VRRP协议介绍及一些常见问题
  • C语言实现的冰墩墩
  • 搭建简易的rtsp服务器
  • 五一“拼假”催热超长假期,热门酒店民宿一房难求
  • 靳燕出任中央戏剧学院党委副书记,原任中戏院长助理
  • 比亚迪一季度日赚亿元,净利润同比翻倍至91.55亿元
  • 沈阳市委常委马原出任阜新市委副书记、市政府党组书记
  • 女子隐私被“上墙”莫名遭网暴,网警揪出始作俑者
  • 打破“内卷”与“焦虑”怪圈,在阅读中寻找松弛感