热门标签 | 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;
}

推荐阅读
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 本文介绍如何在应用程序中使用文本输入框创建密码输入框,并通过设置掩码来隐藏用户输入的内容。我们将详细解释代码实现,并提供专业的补充说明。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
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社区 版权所有