\(\mathcal{Description}\)

  一段坐标轴 \([0,L]\),从 \(0\) 出发,每次可以 \(+a\) 或 \(-b\),但不能越出 \([0,L]\)。求可达的整点数。

  \(L\le10^{12}\),\(1\le a,b\le10^5\)。

\(\mathcal{Solution}\)

\(\mathcal{Case~1}\)

  考场上玄学操作,天知道为什么兔子签到的姿势如此诡异。

  显然先约 \(\gcd\)。我们从 \(0\) 次开始枚举 \(-b\) 的次数,设当前枚举到 \(k\),若 \(kb\equiv0\pmod a\),可以通过少一次 \(a\) 来完成,调出循环;否则,钦定 \(k\) 次 \(-b\) 时,可达的整点一定是一个模 \(a\) 剩余类中连续的区间,即 \(l,l+a,l+2a,\cdots,r\)。我们只需要维护出 \((l,r)\),累加 \(\frac{r-l}a+1\) 就能得到答案。考虑多一次 \(-b\) 对 \((l,r)\) 的影响,例如当 \(a=4,b=3\):

\[-~~~~-~~~~l~~~~-~~~~-~~~~-~~~~l+a~~~~-~~~~-~~~~-~~~~r~~~~-
\]

  首先左移 \(b\) 位,类似位运算,出界的低位被销毁:

\[-~~~~-~~~~-~~~~l+a~~~~-~~~~-~~~~-~~~~r~~~-~~~~-~~~~-~~~~-
\]

  这个时候需要判断是否存在 \(l+ka\)(可能 \(b\) 是 \(a\) 的若干倍,不仅是一个 \(+a\) 可以拉回来的),若不存在,跳出。然后考虑更新 \(r\),它还能往后 \(+a\),一直顶满上限:

\[-~~~~-~~~~-~~~~l+a~~~~-~~~~-~~~~-~~~~r-a~~~-~~~~-~~~~-~~~~r
\]

  于是模拟一下就解决了。复杂度 \(\mathcal O(a+b)\)。

\(\mathcal{Case~2}\)

  可以打表证明当 \(a+b-1>L\),答案为 \(L+1\);否则暴力 DFS……

  兔子可能是个傻瓜,嗯。

\(\mathcal{Code}\)

// case 1
#include <cstdio> typedef long long LL; inline char fgc () {
static char buf[1 << 17], *p = buf, *q = buf;
return p == q && ( q = buf + fread ( p = buf, 1, 1 << 17, stdin ), p == q ) ? EOF : *p ++;
} inline LL rint () {
LL x = 0; char s = fgc ();
for ( ; s < '0' || '9' < s; s = fgc () );
for ( ; '0' <= s && s <= '9'; s = fgc () ) x = x * 10 + ( s ^ '0' );
return x;
} inline void wint ( const LL x ) {
if ( 9 < x ) wint ( x / 10 );
putchar ( x % 10 ^ '0' );
} LL L, a, b;
bool vis[100005]; inline LL gcd ( const LL a, const LL b ) {
return b ? gcd ( b, a % b ) : a;
} int main () {
freopen ( "river.in", "r", stdin );
freopen ( "river.out", "w", stdout );
L = rint (), a = rint (), b = rint ();
int d = gcd ( a, b );
a /= d, b /= d, L /= d;
if ( a == 1 ) return wint ( L + 1 ), putchar ( '\n' ), 0;
if ( b == 1 ) return wint ( a > L ? 1 : L + 1 ), putchar ( '\n' ), 0;
LL ans = L / a + 1, l = 0, r = a * ( L / a );
vis[0] = true;
for ( int useb = 1; !vis[1ll * useb * b % a]; ++ useb ) {
vis[useb * b % a] = true;
l -= b;
if ( l < 0 ) l += a * ( ( -l - 1 ) / a + 1 );
if ( l + b > r ) break;
r -= b;
if ( L - r >= a ) r += a * ( ( L - r ) / a );
if ( l > r ) break;
ans += ( r - l ) / a + 1;
}
wint ( ans ), putchar ( '\n' );
return 0;
}

\(\mathcal{Details}\)

  还陷在省选难度签不动道的怪圈里……这道题算上拍浪费了差不多 \(40min\)。

  麻烦兔子醒醒啊!

Solution -「LOCAL」过河的更多相关文章

  1. Solution -「LOCAL」二进制的世界

    \(\mathcal{Description}\)   OurOJ.   给定序列 \(\{a_n\}\) 和一个二元运算 \(\operatorname{op}\in\{\operatorname{ ...

  2. Solution -「LOCAL」大括号树

    \(\mathcal{Description}\)   OurTeam & OurOJ.   给定一棵 \(n\) 个顶点的树,每个顶点标有字符 ( 或 ).将从 \(u\) 到 \(v\) ...

  3. Solution -「LOCAL」Drainage System

    \(\mathcal{Description}\)   合并果子,初始果子的权值在 \(1\sim n\) 之间,权值为 \(i\) 的有 \(a_i\) 个.每次可以挑 \(x\in[L,R]\) ...

  4. Solution -「LOCAL」Burning Flowers

      灼之花好评,条条生日快乐(假装现在 8.15)! \(\mathcal{Description}\)   给定一棵以 \(1\) 为根的树,第 \(i\) 个结点有颜色 \(c_i\) 和光亮值 ...

  5. Solution -「LOCAL」画画图

    \(\mathcal{Description}\)   OurTeam.   给定一棵 \(n\) 个点的树形随机的带边权树,求所有含奇数条边的路径中位数之和.树形生成方式为随机取不连通两点连边直到全 ...

  6. Solution -「LOCAL」ZB 平衡树

    \(\mathcal{Description}\)   OurOJ.   维护一列二元组 \((a,b)\),给定初始 \(n\) 个元素,接下来 \(m\) 次操作: 在某个位置插入一个二元组: 翻 ...

  7. Solution -「LOCAL」舟游

    \(\mathcal{Description}\)   \(n\) 中卡牌,每种三张.对于一次 \(m\) 连抽,前 \(m-1\) 次抽到第 \(i\) 种的概率是 \(p_i\),第 \(m\) ...

  8. Solution -「LOCAL」充电

    \(\mathcal{Description}\)   给定 \(n,m,p\),求序列 \(\{a_n\}\) 的数量,满足 \((\forall i\in[1,n])(a_i\in[1,m])\l ...

  9. Solution -「LOCAL」「cov. 牛客多校 2020 第五场 C」Easy

    \(\mathcal{Description}\)   Link.(完全一致)   给定 \(n,m,k\),对于两个长度为 \(k\) 的满足 \(\left(\sum_{i=0}^ka_i=n\r ...

随机推荐

  1. Leetcode算法系列(链表)之两数相加

    Leetcode算法系列(链表)之两数相加 难度:中等给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.如果,我们将 ...

  2. Win10+Java7环境配置

    原文链接: https://www.toutiao.com/i6487838676326810125/ 安装包: jdk-7u79-windows-x64-20151024 打开安装目录 双击运行程序 ...

  3. 【Python自动化Excel】pandas处理Excel数据的基本流程

    这里所说的pandas并不是大熊猫,而是Python的第三方库.这个库能干嘛呢?它在Python数据分析领域可是无人不知.无人不晓的.可以说是Python世界中的Excel. pandas库处理数据相 ...

  4. Golang 常见设计模式之选项模式

    熟悉 Python 开发的同学都知道,Python 有默认参数的存在,使得我们在实例化一个对象的时候,可以根据需要来选择性的覆盖某些默认参数,以此来决定如何实例化对象.当一个对象有多个默认参数时,这个 ...

  5. C#进程调用FFmpeg操作音视频

    项目背景 因为公司需要对音视频做一些操作,比如说对系统用户的发音和背景视频进行合成,以及对多个音视频之间进行合成,还有就是在指定的源背景音频中按照对应的规则在视频的多少秒钟内插入一段客户发音等一些复杂 ...

  6. Vue3项目的简单搭建与项目结构的简单介绍

    Vue3项目的创建与运行 本文记录下自己近期学习的Vue3项目的创建,以及如何去运行一个Vue应用,同时包括对Vue项目结构进行一个简单的介绍. 一.node与npm的安装 通常平常进行开发的同学应该 ...

  7. rocketmq学习之-基本样例

    1 基本样例 在基本样例中我们提供如下的功能场景: 使用RocketMQ发送三种类型的消息:同步消息.异步消息和单向消息.其中前两种消息是可靠的,因为会有发送是否成功的应答. 使用RocketMQ来消 ...

  8. MySQL 5.7 版本的 UTF8 字符集调研

    一.故事背景 记一次 sql_mode 非严格模式下的业务事故排查.当时数据库没有开启 sql_mode 为严格模式,并且数据表的编码是 utf8,表现为业务侧的 Insert SQL 语句执行成功, ...

  9. 小记录:flask的DEBUG开关

    请求站点的如下位置: http://www.ahfu.com/ahfuzhang/?debugger=yes&cmd=resource&f=style.css 居然正常范围了CSS文件 ...

  10. C#语言类型

    讨论 所有类型在,值类型,引用类型用new创建,值类型由编译器自动补全 int等引用类型是轻量化结构更像是结构体 值类型在栈中,引用类型在堆中 所有类型由类派生,可以说每个是对象,也可以不是 由于.N ...