CF1146D Frog Jumping

洛谷评测传送门

题目描述

A frog is initially at position 00 on the number line. The frog has two positive integers aa and bb . From a position kk , it can either jump to position k+ak+a or k-bkb .

Let f(x)f(x) be the number of distinct integers the frog can reach if it never jumps on an integer outside the interval [0, x][0,x] . The frog doesn't need to visit all these integers in one trip, that is, an integer is counted if the frog can somehow reach it if it starts from 00 .

Given an integer mm , find \sum_{i=0}^{m} f(i)∑i=0m**f(i) . That is, find the sum of all f(i)f(i) for ii from 00 to mm .

输入格式

The first line contains three integers m, a, bm,a,b ( 1 \leq m \leq 10^9, 1 \leq a,b \leq 10^51≤m≤109,1≤a,b≤105 ).

输出格式

Print a single integer, the desired sum.

题意翻译

yyb大神仙在数轴的00位置。yyb大神仙有两个正整数a,ba,b,如果当前yyb大神仙在位置kk,yyb大神仙可以用神仙的力量将自己传送到k+ak+a或者k-bkb位置。

但是yyb大神仙感觉这样很无聊所以打算将自己限制在一段区间里。f(x)f(x)表示yyb大神仙只能在[0,x][0,x]区间里移动,从00开始能到达的整点数量。yyb大神仙想求\sum_{i=0}^mf(i)∑i=0m**f(i)。

输入输出样例

输入 #1复制

输出 #1复制

输入 #2复制

输出 #2复制

输入 #3复制

输出 #3复制

输入 #4复制

输出 #4复制

说明/提示

In the first example, we must find f(0)+f(1)+\ldots+f(7)f(0)+f(1)+…+f(7) . We have f(0) = 1, f(1) = 1, f(2) = 1, f(3) = 1, f(4) = 1, f(5) = 3, f(6) = 3, f(7) = 8f(0)=1,f(1)=1,f(2)=1,f(3)=1,f(4)=1,f(5)=3,f(6)=3,f(7)=8 . The sum of these values is 1919 .

In the second example, we have f(i) = i+1f(i)=i+1 , so we want to find \sum_{i=0}{109} i+1∑i=0109i+1 .

In the third example, the frog can't make any jumps in any case.

题解:

2019.10.28模拟赛T2 60分场

出题人@Winniechen的数据挺良心的(滑稽)

我很疑惑,为什么大佬们一开始都能想到找规律出正解。我一开始只能想到深搜,所以用一个差不多是\(O(n^2)\)的算法拿了\(10^3\)的分,假如数据是按上面说的:\(10^9\),这个算法得跑31年...

先贴一份代码:

#include<cstdio>
#include<algorithm>
#include<cstring>
#define int long long
using namespace std;
const int maxn=1e5+10;
int n,a,b,cnt,ans;
bool v[maxn];
void dfs(int pos,int l)
{
if(pos<0 || pos>l || v[pos])
return;
v[pos]=1;
cnt++;
dfs(pos+a,l);
dfs(pos-b,l);
}
signed main()
{
scanf("%lld%lld%lld",&n,&a,&b);
for(int i=0;i<=n;i++)
{
cnt=0;
memset(v,0,sizeof(v));
dfs(0,i);
ans+=cnt;
}
printf("%lld",ans);
return 0;
}

这就是编程的魅力,一再优化,你的31年,人家的一秒,这就是差距。国家实力就是这么被提升起来的。

接下来介绍正解:

根据我们手推样例,不难发现,会有一个路径让我们返回到出发点,这样的话就会开始循环跳来跳去。(其实这是我深搜的时候发现的),所以我们会发现一个性质:在一个区间中,如果有一个点能到达,那么这个点一定是\(\gcd(a,b)\)的倍数。

证明其实也好证:

假设我们向右跳了\(x\)次,向左跳了\(y\)次。那么就会存在一个点\(k\):

\[ax+by=k
\]

显然\(k\)一定是\(\gcd(a,b)\)的倍数。

那我们回头来求这个函数\(f(i)\),不难看出,当\(a>i\)的时候,总和就是\(a\),因为根本就动弹不了。

所以当\(n<a\)的时候就输出\(n+1\)即可(加的那个\(1\)代表\(f(0)\))。

否则我们一次性在答案上加\(a\)(一次性累加\(f(0)-f(a-1)\))。

然后我们在\([a,i]\)这个区间上寻找一个可以让路径回到出发点的点\(k\),这样的话我们就相当于处理出了一个临界值,之后的东西可以用刚才我们推出的规律处理。这个处理过程其实是一个模拟的过程,先一直往右跳,再一直往左跳,什么时候正好跳回来了就标记上(这个省略了标记的步骤,因为直接拿\(i\)记录了),最后加上跳跃的次数。

很显然,这种一次枚举跳很多步的时间复杂度是很优秀的。

这个时候跳出循环,然后按照我们发现的规律:所有可被到达的点都是\(\gcd(a,b)\)的倍数。这样处理出其他的点到\(n\)的情况。进行累加答案,输出即可。

代码:

#include<cstdio>
#define int long long
using namespace std;
int n,a,b,pos,i;
int ans,tmp=1;
int gcd(int x,int y)
{
return y?gcd(y,x%y):x;
}
signed main()
{
scanf("%lld%lld%lld",&n,&a,&b);
ans+=a;
if(n<a)
{
printf("%lld",n+1);
return 0;
}
for(i=a;i;i++)
{
while(pos+a<=i)
{
tmp+=((i-pos)/a);
pos+=((i-pos)/a)*a;
tmp+=(pos/b);
pos%=b;
if(!pos)
break;
}
if(!pos)
break;
ans+=tmp;
if(n==i)
break;
}
if(!pos)
{
int p=gcd(a,b);
int j=n-n%p;
tmp=(int)(i+j)*(j/p-i/p+1)/2;
tmp-=(int)(j+p-1-n)*(j/p);
ans+=tmp+n-i+1;
}
printf("%lld",ans);
return 0;
}

CF1146D Frog Jumping的更多相关文章

  1. [CF1146D]Frog Jumping_exgcd_堆优化dij

    Frog Jumping 题目链接:http://codeforces.com/contest/1146/problem/D 数据范围:略. 题解: 首先发现,如果$x\ge a +b$,那么所有的$ ...

  2. CodeForces Round #521 (Div.3) A. Frog Jumping

    http://codeforces.com/contest/1077/problem/A A frog is currently at the point 00 on a coordinate axi ...

  3. CF1077A Frog Jumping 题解

    Content 在一个数轴上有一个动点,初始时在 \(0\) 这个位置上,接下来有若干次操作,对于第 \(i\) 次操作: 如果 \(i\) 是奇数,那么动点往右移 \(a\) 个单位. 如果 \(i ...

  4. 杭州集训Day4

    别问我为什么没有前三天,有时间再补~ 60+60+50=170. T1 . 坐等 memset0 ( 1s 256MB )( 原题:洛谷CF1151E Number of Components ) 树 ...

  5. 【CF1146】Forethought Future Cup - Elimination Round

    Forethought Future Cup - Elimination Round 窝也不知道这是个啥比赛QwQ A. Love "A" 给你一个串,你可以删去若干个元素,使得最 ...

  6. XVIII Open Cup named after E.V. Pankratiev. Ukrainian Grand Prix

    A. Accommodation Plan 对于已知的$K$个点,离它们距离都不超过$L$的点在树上是一个连通块,考虑在每种方案对应的离$1$最近的点统计. 即对于每个点$x$,统计离它距离不超过$L ...

  7. CodeForces Round 521 div3

    A:Frog Jumping 代码: #include<bits/stdc++.h> using namespace std; #define Fopen freopen("_i ...

  8. Codeforces Forethought Future Cup Elimination Round 选做

    1146C Tree Diameter 题意 交互题.有一棵 \(n(n\le 100)\) 个点的树,你可以进行不超过 \(9\) 次询问,每次询问两个点集中两个不在同一点集的点的最大距离.求树的直 ...

  9. 2017年上海金马五校程序设计竞赛:Problem I : Frog's Jumping (找规律)

    Description There are n lotus leaves floating like a ring on the lake, which are numbered 0, 1, ..., ...

随机推荐

  1. Java多态的总结

    多态 多态是一个对象具有不同表现形态或形式的能力,根据不同的实例执行不同的操作,例如打印机具有打印功能,打印机又有彩色打印机和黑白打印机,彩色打印机的实例打印出来的是彩色,黑白打印机打印出来的是黑色, ...

  2. 任意视频批量转码MP4-H264助手

    使用说明 简单的粗暴的小工具,利用windows命令行调用ffmpeg完成任意格式视频转换成H264编码的MP4视频,以确保视频可以在主流浏览器中直接播放,如:Chrome.Firefox等. 只需要 ...

  3. JS 查找数组的父节点及祖先节点

    function findAllParent(node, tree, parentNodes=[], index = 0){ if(!node || node.parentId === 0){ ret ...

  4. 黄聪:mysql的SQL_CALC_FOUND_ROWS 使用 类似count(*) 使用性能更高

    mysql的SQL_CALC_FOUND_ROWS 使用 类似count(*) 使用性能更高 在很多分页的程序中都这样写: SELECT COUNT(*) from `table` WHERE ... ...

  5. RabbitMQ的交换器Exchange之direct(发布与订阅 完全匹配)

    1.交换器.用来接收生产者发送的消息并将这些消息路由给服务器中的队列.三种常用的交换器类型,a.direct(发布与订阅 完全匹配).b.fanout(广播).c.topic(主题,规则匹配). 2. ...

  6. HTTP Error 500.0 - ANCM In-Process Handler Load Failure 排错历程

    先上报错图 环境 Window Server 2008 r2 netcore 2.2 排错历程 看到这个错 我第一个想到netcore 安装问题 先检查了下环境 发现没问题 我排查了下应用池 确定是无 ...

  7. Vue响应式原理及总结

    Vue 的响应式原理是核心是通过 ES5 的保护对象的 Object.defindeProperty 中的访问器属性中的 get 和 set 方法,data 中声明的属性都被添加了访问器属性,当读取 ...

  8. SIP协议分析

    - SIP流程 一个标准的SIP通话流程如下: 1. A向B发送一个INVITE消息,邀请B通话. 2.B振铃,向A回复一个RING消息,通知A振铃中,A等待. 3.B提机,向A发一个OK消息,  通 ...

  9. 【转载】Android 的 Handler 机制实现原理分析

    handler在安卓开发中是必须掌握的技术,但是很多人都是停留在使用阶段.使用起来很简单,就两个步骤,在主线程重写handler的handleMessage( )方法,在工作线程发送消息.但是,有没有 ...

  10. Android Activity 开发常用技巧整理

    1.设置 Activity 背景色为透明 在style.xml里面声明: <style name="TranslucentActivityStyle" parent=&quo ...