热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CF1245F:清理春天的数学挑战

题目CF1245F:清理春天的数学挑战描述了一个数学问题:给定一个区间[L,R](0≤L,R≤10^9),求该区间内满足x+y=x∧y的数对(x,y)的总数。

CF1245F: 清理春天的数学挑战


题目描述:


本题涉及一个数学挑战,给定一个区间 [L, R],其中 0 ≤ L, R ≤ 10^9。任务是在这个区间内找到所有满足 x + y = x ∧ y 的数对 (x, y),并计算这些数对的总数。


输入说明:



  • 首行输入一个整数 T,表示测试用例的数量。

  • 接下来 T 行,每行包含两个整数 L 和 R,代表区间的起始和结束位置。


输出说明:



  • 对于每个测试用例,输出一行,包含一个整数,即满足条件的数对总数。


解题思路:


关键在于理解等式 x + y = x ∧ y 的含义,这实际上意味着 x 和 y 在二进制表示中没有相同的 1 位,即 x ∧ y = 0。因此,问题转化为寻找区间内 x ∧ y = 0 的数对。


为了高效解决这个问题,我们定义了几个辅助函数来帮助计算:



  • f(l, r): 表示区间 [l, r) 内满足条件的数对数量。

  • g(x, n): 表示在 0 到 n 范围内,与 x 进行按位与运算结果为 0 的数 y 的数量。

  • h(x, n): 表示在 n - lowbit(n) 到 n 范围内,与 x 进行按位与运算结果为 0 的数 y 的数量。


通过递归地将区间缩小,并利用上述函数,可以有效地计算出最终结果。特别是当 l 或 r 为奇数时,需要特殊处理,确保计算的准确性。


代码实现:


#include
using namespace std;
typedef long long ll;

ll g(int a, int b)
{
ll res = 0;
ll num = 0;

for(int i = 1; i <= b; i <<= 1)
{
if(b & i)
{
b ^= i;
if(!(a&b)) res += 1< }
if(!(a&i)) num++;
}

return res;
}

ll calc(int a, int b)
{
if(a == b) return 0;
if(a == 0) return 2*b - 1 + calc(1, b);
ll res = 0;
if(a & 1)
{
// f(l,r)=f(l+1,r)+2(g(l,r)-g(l,l))
res += 2 * (g(a, b) - g(a,a));
a++;
}
if(b & 1)
{
// f(l,r)=f(l,r-1)+2(g(r-1,r)-g(r-1,l))
res += 2 * (g(b-1, b) - g(b-1, a));
b--;
}
return res + 3 * calc(a/2, b/2);
}

int main()
{
int T; cin >> T;
int a, b;
while(T--)
{
cin >> a >> b;
cout < }
return 0;
}

推荐阅读
  • EasyMock实战指南
    本文介绍了如何使用EasyMock进行单元测试,特别是当测试对象的合作者依赖于外部资源或尚未实现时。通过具体的示例,展示了EasyMock在模拟对象行为方面的强大功能。 ... [详细]
  • MySQL锁机制详解
    本文深入探讨了MySQL中的锁机制,包括表级锁、行级锁以及元数据锁,通过实例详细解释了各种锁的工作原理及其应用场景。同时,文章还介绍了如何通过锁来优化数据库性能,避免常见的并发问题。 ... [详细]
  • Python数据类型6 字典
    字典Python的字典数据类型是基于hash散列算法实现的,采用键值对(key:value)的形式,根据key的值计算value的地址,具有非常快的查取和插入速度。但它是无序的,包 ... [详细]
  • 本文详细介绍了在使用Socket进行网络编程时,遇到链接器错误`undefined reference to WSAStartup@8`的解决方案,适用于多种开发环境。 ... [详细]
  • 本次CSPS模拟测试中,面对算法挑战,作者经历了一次心态与技术的双重考验。通过不断尝试与调整,最终克服了遇到的难题。 ... [详细]
  • 新手指南:在Windows 10上搭建深度学习与PyTorch开发环境
    本文详细记录了一名新手在Windows 10操作系统上搭建深度学习环境的过程,包括安装必要的软件和配置环境变量等步骤,旨在帮助同样初入该领域的读者避免常见的错误。 ... [详细]
  • Java与JSON互转:实现JSON到Java对象及Java对象到JSON的转换
    本文详细介绍了如何在Java中实现JSON数据与Java对象之间的相互转换,包括代码示例和常见问题解决方法。 ... [详细]
  • 本文探讨了如何利用SqlDependency执行复杂的SQL查询,并确保在多线程环境下的安全性与效率。 ... [详细]
  • 本文详细介绍了ActivityManagerService (AMS) 的工作原理及其在Android系统中的重要角色。AMS作为system_server进程的一部分,在系统启动时加载,负责管理和协调应用程序中的Activity和服务(Service)。文章将通过具体的接口图和通信流程,帮助读者更好地理解AMS的工作机制。 ... [详细]
  • 本文探讨了为何需要进行详尽的需求分析,以及在软件开发过程中常见的需求类型。同时,介绍了几种有效的方法来确保能够准确地捕捉到用户的实际需求。 ... [详细]
  • JavaWeb技术架构解析
    本文探讨了JavaWeb开发中客户端与服务器端的交互模式,重点分析了B/S(浏览器/服务器)和C/S(客户端/服务器)两种架构的特点及应用场景。 ... [详细]
  • 深入理解Python编程
    本文探讨了作者在学习Python过程中遇到的挑战和转折点,以及如何通过找到合适的资源和方法来提升编程技能。对于初学者来说,这不仅是一个学习的过程,也是一个自我发现和调整学习策略的过程。 ... [详细]
  • 本文介绍了如何使用JavaScript和jQuery实现页面元素随着滚动条的移动而相应变化位置的功能,提供了一段简洁的代码示例。 ... [详细]
  • iTOP4412开发板QtE5.7源码编译指南
    本文详细介绍了如何在iTOP4412开发板上编译QtE5.7源码,包括所需文件的位置、编译器设置、触摸库编译以及QtE5.7的完整编译流程。 ... [详细]
  • Scrapy:强大的Python爬虫框架
    Scrapy是一个基于Python的高效网页爬取框架,利用Twisted异步网络库实现高效的网络通信。其架构设计精巧,包括核心组件如引擎、调度器、下载器等,旨在简化大规模数据抓取过程。 ... [详细]
author-avatar
2yuheng
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有