首页 技术 正文
技术 2022年11月8日
0 收藏 825 点赞 1,694 浏览 1204 个字

Problem J: 连分数

Time Limit: 1 Sec  Memory Limit: 64 MB
Submit: 2723  Solved: 801
[Submit][Status][Web Board]

Description

一个高为n的连分数定义为 。

给出2个数,一个用p/q的方式表达,另一个用高度为n的连分数来表示,请你判断他们是否相等。

Input

输入有多组,每组包含两部分用来表示两种形式的分数:第一部分是pq(1 ≤ q ≤ p ≤ 10^18),表示分数p/q;然后是一个数字n(1 ≤ n ≤ 90)和由n个数 ai(1 ≤ ai ≤ 10^18)代表的连分数。

Output

如果相等请输出“YES”,否则输出“NO”。

Sample Input

9 422 49 432 3 1

Sample Output

YESYES

HINT

Append Code

这道题目适合用递归写,思路一开始就是对的,但由于自己缺乏对细节的掌控能力,逻辑思维一直以来不是很严密(可能跟高数学的不好有关),一开始考虑问题不全面,导致题目错了很多次。

因此,得到的很重要的教训有:

1.仔细考虑好思路再动手写程序,如果写程序过程中有明显的卡顿,证明自己思路还不够清晰,停下来想清楚再写;

2.测试程序的时候注意边缘数据,边缘数据一般在题目给的范围中找,例如特别大,或者特别小的数。在这个题中最好n=1,2,3自己推一遍,此外自己多构造几组数据测试一下;

 #include <stdio.h>
unsigned long long last=;
unsigned long long num[];
unsigned long long gcd(unsigned long long a,unsigned long long b){
return (a==) ? b: gcd(b%a,a);
}
unsigned long long fun(int n){
if(n == ) return ;
unsigned long long d=num[n];
unsigned long long k=fun(n-);
unsigned long long t=k*d+last;
last=k;
return t;
}
int main(){
int n;
unsigned long long p,q,t;
while(scanf("%llu%llu",&p,&q)!=EOF){
last=;
scanf("%d",&n);
for(int i=n; i>=; i--)
scanf("%llu",&num[i]);
if(n!=){
num[]--;
t = fun(n);
}
else {
t = ;
last = num[n];
}
unsigned long long gcd1 = gcd(p,q);
unsigned long long gcd2 = gcd(last,t);
if(p / gcd1 == t / gcd2 && q / gcd1 == last / gcd2)
printf("YES\n");
else
printf("NO\n");
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,130
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,601
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,444
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,218
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,852
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,940