C

来源:互联网 发布:2017最新拼图软件 编辑:程序博客网 时间:2024/06/06 21:38

点击打开链接

GCD(最大公约数)

最大公约数指某几个整数共有因子中最大的一个。

GCD即Greatest Common Divisor.

例如,12和30的公约数有:1、2、3、6,其中6就是12和30的最大公约数。

代码:

迭代实现:int Gcd(int a, int b){    while(b != 0)    {      int r = b;      b = a % b;      a = r;    }    return a;}递归实现:int gcd(int a,int b){    if(b==0)        return a;    return         gcd(b,a%b);}

LCM(最小公倍数)

和最大公约数(gcd)的关系:gcd(a, b)×lcm(a, b) = ab。

代码:

int lcm(int a,int b){return a/gcd(a,b)*a;}


有三个正整数a,b,c(0<a,b,c<10^6),其中c不等于b。若a和c的最大公约数为b,现已知a和b,求满足条件的最小的c。 
Input
第一行输入一个n,表示有n组测试数据,接下来的n行,每行输入两个正整数a,b。 
Output
输出对应的c,每组测试数据占一行。 
Sample Input
26 212 4
Sample Output
48

题意:根据最大公约数与最小公倍数的关系,已知一个数a与最大公约数,求得另一个数(最小值)。

题解:设另一个数为最大公约数的的整数倍(从2开始)得到n,再判断n与a的最大公约数为b,直到出现第一个满足条件的m(最小值)。


代码:

#include<cstdio>#include<iostream>using namespace std;int gcd(int a,int b){   if(b==0)   return a;   return gcd(b,a%b);}int main(){int i,j,n,m,c,k,t;scanf("%d",&j);for(i=1;i<=j;i++) {scanf("%d%d",&n,&m);c=m*2;while(gcd(c,n)!=m)c+=m;printf("%d\n",c);}return 0;}








原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 激活淘宝时显示注册账号过多怎么办 科学上网之后电脑上不了网怎么办 阴阳师地域鬼王定位在非洲怎么办 网吧忘记下机有小孩玩我号怎么办 等了三年老公还是不跟小三断怎么办 小三生孩子老公为责任断不了怎么办 没离婚去医院生孩子刷身份证怎么办 小孩早晨起床鼻子痒有鼻涕怎么办 孩子鼻梁上方和眼眶磕肿了怎么办 宝宝开空调冻的流鼻涕打喷嚏怎么办 狼人杀带耳机麦没声音怎么办 王者荣耀边境突围使刘邦大招怎么办 如果有个恶毒又有心机的后妈怎么办 qq炫舞的好忘了怎么办 百度网盘别人发我一个链接我怎么办 感觉地下和墙壁里有蚂蚁怎么办? 射像头监控摄像头家用卡满了怎么办 微乐贵阳捉鸡麻将不显示头像怎么办 苹果6p用久了卡怎么办 小猪民宿平台限制三天上线怎么办 交易猫买家申请了仲裁我的钱怎么办 雷达石英手表表里面有小灰尘怎么办 电脑宽带用户名和密码忘记了怎么办 腾讯会员不让别人在异地登录怎么办 中毒后电脑文件后缀是lnk怎么办 wps逗号隔的空不一样大怎么办 电脑盘里的文件删不了怎么办 在淘宝买的qq账号被找回了怎么办 微信公众号的密码忘了怎么办 公众号安全助手密码忘了怎么办 微博账号存在发布违规信息怎么办 余额宝转出到银行卡被冻结怎么办 银行账户被冻结被转出钱怎么办 从余额宝转出的资金被冻结怎么办 微信账号卖了但是实名认证了怎么办 uc下载文档里的文档全没了怎么办 二手乐视没有账号和密码怎么办 华为账号密码忘了手机卡丢了怎么办 联想平板微信更新后不可兼容怎么办 小米手机刷完机账号密码忘了怎么办 红米手机的小米账号密码忘了怎么办