Update

  • \(\texttt{2020.10.21}\) 删除了不需要的 \(n=1\) 的特判,并在符号与字母之间添加了空格。

Content

给定一个数 \(n\),试找到一对数 \(a,b(1\leqslant a,b\leqslant n)\),使得 \(a~or~b+a~xor~b\) 的值最大。

数据范围:\(2\leqslant n\leqslant 10^{18}\)。

Solution

和月赛 T1 一样是个找规律题。

我们先对 \(n=100\) 以内的答案通过打表得出来,先弄个打表程序:

#include <cstdio>
#include <algorithm>
using namespace std; int n, ans; int main() {
for(n = 1; n <= 100; ++n) {
ans = 0;
for(int i = 1; i <= n; ++i)
for(int j = 1; j <= n; ++j)
ans = max(ans, (i | j) + (i ^ j));
printf("When n = %d, ans = %d.\n", n, ans);
}
return 0;
}

以下是得出来的结果,为了不占太大版面,相同的答案就直接省略了。

When n = 1, ans = 1.
When n = 2, ans = 6.
When n = 3, ans = 6.
When n = 4, ans = 14.
...
When n = 7, ans = 14.
When n = 8, ans = 30.
...
When n = 15, ans = 30.
When n = 16, ans = 62.
...
When n = 31, ans = 62.
When n = 32, ans = 126.
...
When n = 63, ans = 126.
When n = 64, ans = 254.
...
When n = 100, ans = 254.

通过每一个 \(n\) 对应的答案我们就可以找到规律:

\((2=2^1)\leqslant n\leqslant (3=2^2-1)\) 的时候,答案是 \(6=2^3-2\)。

\((4=2^2)\leqslant n\leqslant (7=2^3-1)\) 的时候,答案是 \(14=2^4-2\)。

\((8=2^3)\leqslant n\leqslant (15=2^4-1)\) 的时候,答案是 \(30=2^5-2\)。

\((16=2^4)\leqslant n\leqslant (31=2^5-1)\) 的时候,答案是 \(62=2^6-2\)。

\((32=2^5)\leqslant n\leqslant (63=2^6-1)\) 的时候,答案是 \(126=2^7-2\)。

由此我们发现:当有一个 \(i\) 满足 \(2^i\leqslant n\leqslant 2^{i+1}\) 的时候,答案就是 \(2^{i+2}-2\)。所以,我们找到最小的 \(i\) 使得 \(n<2^i\),然后此时答案就是 \(2^{i+1}-2\)。注意,由于这里的数据范围是从 \(2\) 开始,所以不需要特判 \(n=1\) 的情况。

Code

#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std; long long n; int main() {
scanf("%lld", &n);
for(int i = 1; ; ++i)
if(n < (long long)pow(2, i)) {
printf("%lld", (long long)pow(2, i + 1) - 2);
break;
}
return 0;
}

LuoguP6861 [RC-03] 难题 题解的更多相关文章

  1. Hdoj 2045.不容易系列之(3)—— LELE的RPG难题 题解

    Problem Description 人称"AC女之杀手"的超级偶像LELE最近忽然玩起了深沉,这可急坏了众多"Cole"(LELE的粉丝,即"可乐 ...

  2. T3 难题 题解

    小王在考试中遇到一道难题:方程 a1+a2+„„+an=m 的非负整数解有几个,请你帮他算 一下(这也可以算作他作弊吧). 输入格式 一行,两个以空格隔开的数 n,m,表示方程 a1+a2+„„+an ...

  3. [难题题解] [BZOJ1875] [SDOI2009] HH去散步

    题目H有个一成不变的习惯,喜欢饭后百步走.所谓百步走,就是散步,就是在一定的时间 内,走过一定的距离. 但是同时HH又是个喜欢变化的人,所以他不会立刻沿着刚刚走来的路走回. 又因为HH是个喜欢变化的人 ...

  4. 【基础练习】【BFS+A*】codevs1225八数码难题题解

    题目描写叙述 Description Yours和zero在研究A*启示式算法.拿到一道经典的A*问题,可是他们不会做,请你帮他们. 问题描写叙述 在3×3的棋盘上,摆有八个棋子,每一个棋子上标有1至 ...

  5. 洛谷 P1379 八数码难题 题解

    我个人感觉就是一道bfs的变形,还是对bfs掌握不好的人有一定难度. 本题思路: 大体上用bfs搜,用map来去重,在这里只需要一个队列,因为需要较少步数达到的状态一定在步数较多的状态之前入队列. # ...

  6. [BJOI2017]树的难题 点分治 线段树

    题面 [BJOI2017]树的难题 题解 考虑点分治. 对于每个点,将所有边按照颜色排序. 那么只需要考虑如何合并2条链. 有2种情况. 合并路径的接口处2条路径颜色不同 合并路径的接口处2条路径颜色 ...

  7. Weapsy 分析网站架构

    Weapsy 分析(一)网站架构 这个项目看了好久了,但是老没时间写一些分析心得.下班后想了想,事情也不能老拖着,还是得做. 如图所示:Weapsy由5个项目所组成,有点可惜了,没有测试的项目,说明一 ...

  8. 【35.39%】【hdu 3333】Turing Tree

    Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...

  9. 2018HDU多校训练一 K - Time Zone

    Chiaki often participates in international competitive programming contests. The time zone becomes a ...

随机推荐

  1. 通过get方法的方式获取配置项信息

    这种写法比其他的方法好的一点是,当你需要修改参数名或者参数值的时候,只需要改一个地方就可以了,其他地方根本不用动,面向接口编程. eureka-server.properties archaius.d ...

  2. Sentry 监控 - Snuba 数据中台架构(SnQL 查询语言简介)

    本文描述了 Snuba 查询语言 (SnQL). 系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒 ...

  3. P4550 收集邮票 与 灵异的期望

    考前复习一下期望相关知识,这题的期望还是很巧妙的. 设 \(f_{i}\) 表示已经买到了 \(i\) 张不同的邮票的期望步数,\(g_{i}\) 表示表示已经买到了 \(i\) 张不同的邮票的期望花 ...

  4. 前端4 — jQuery — 更新完毕

    1.下载jQuery 网址:Download jQuery | jQuery  最好下载最新版的,因为有什么bug问题,最新版的都会有,所以学技术就用最新版的,实际开发用的时候就要讲究了 2.开始用j ...

  5. C语言中的各种字符串输入方法

    C语言从stdin读取一行字符串的几种方法 gets gets函数的头文件是<stdio.h>,原型如下: char *gets(char *s); gets从stdin中读入一行内容到s ...

  6. 巩固javaweb第九天

    巩固内容: HTML <base> 元素 <base> 标签描述了基本的链接地址/链接目标,该标签作为HTML文档中所有的链接标签的默认链接: <head> < ...

  7. 日常Java 2021/9/28

    字符串反转 package m; public class m { public static void main(String[] args) { //定义一个字符串 String str = &q ...

  8. Identity Server 4 从入门到落地(七)—— 控制台客户端

    前面的部分: Identity Server 4 从入门到落地(一)-- 从IdentityServer4.Admin开始 Identity Server 4 从入门到落地(二)-- 理解授权码模式 ...

  9. Hive(六)【分区表、分桶表】

    目录 一.分区表 1.本质 2.创建分区表 3.加载数据到分区表 4.查看分区 5.增加分区 6.删除分区 7.二级分区 8.分区表和元数据对应得三种方式 9.动态分区 二.分桶表 1.创建分桶表 2 ...

  10. Android Bitmap 全面解析(二)加载多张图片的缓存处理

    一般少量图片是很少出现OOM异常的,除非单张图片过~大~ 那么就可以用教程一里面的方法了通常应用场景是listview列表加载多张图片,为了提高效率一般要缓存一部分图片,这样方便再次查看时能快速显示~ ...