博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
G-华华对月月的忠诚
阅读量:7213 次
发布时间:2019-06-29

本文共 979 字,大约阅读时间需要 3 分钟。

链接:https://ac.nowcoder.com/acm/contest/392/G

题意:

月月要参加学校的信息学集训,晚上不能陪华华聊天了。不过为了防止华华去和别的小姐姐聊天,浪费时间影响学习,所以月月给华华布置了一项任务。月月给了华华一个类似斐波那契数列的东西,这个数列满足:

F1=A,F2=B,Fi=Fi1+Fi2(i>2)F1=A,F2=B,Fi=Fi−1+Fi−2(i>2)
月月希望华华求出gcd(FN,FN+1)gcd(FN,FN+1)。月月认为,求这个东西需要很长的时间,所以华华就没有机会去和其他小姐姐聊天了。华华自然对月月十分忠诚,选择求出F的每一位后计算答案。但是比赛中的你看到这一题,就没必要那么老实了。现在给定A、B、N,请你求出月月要求的那个数字。答案可能很大,但是不取模。

思路:

gcd(a, b) = gcd(a, b - a)

gcd(Fn, F(n+1)) =gcd(Fn, F(n + 1) - Fn)

Fn = F(n - 1) + F(n - 2) => F(n + 1) = Fn + F(n - 1)

F(n + 1) - Fn = F(n -1)

gcd(Fn, F(n + 1) = gcd(F(n - 1), Fn)

推出,gcd(Fn, F(n + 1) = gcd(A, B)

代码:

#include 
using namespace std;typedef long long LL;int Gcd(int a, int b){ if (b == 0) return a; return Gcd(b, a % b);}int main(){ int a, b; int t = 100; while (t--) { a = rand() % 10000; b = rand() % 10000; cout << Gcd(a, b) << ' '; cout << __gcd(a, b) << endl; } return 0;}

  

转载于:https://www.cnblogs.com/YDDDD/p/10504819.html

你可能感兴趣的文章
Redis基础操作
查看>>
clob大数据转换为多行数据
查看>>
bootstrap的流式布局
查看>>
如何通过线程池异步调用
查看>>
Squid配置详解
查看>>
070104_微积分:随机变量及其分布(二项分布,均匀分布,正态分布)
查看>>
LeetCode – Refresh – Binary Tree Zigzag Level Order Traversal
查看>>
python操作三大主流数据库(13)python操作redis之新闻项目实战①新闻数据的导入
查看>>
2013夏,iDempiere来了 - v1.0c Installers (Devina LTS Release) 2013-06-27
查看>>
每天一个linux命令(22):find 命令的参数详解
查看>>
然后是几点(15)
查看>>
15.节点属性
查看>>
ISO-8859-1编码
查看>>
PHP 代码评审的 10 个提示
查看>>
你知道吗?Web的26项基本概念和技术
查看>>
方案优化:网站实现扫描二维码关注微信公众号,自动登陆网站并获取其信息...
查看>>
Leetcode | Balanced Binary Tree
查看>>
sqlServer对内存的管理
查看>>
挑战密室
查看>>
利用Solr服务建立的站内搜索雏形---solr1
查看>>