鱼C论坛

 找回密码
 立即注册
查看: 1329|回复: 6

[已解决]最大公约数

[复制链接]
发表于 2021-11-25 14:40:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. 函数1(最大公约数)
  2. 题目描述

  3. 输入两个正整数m和n(1<m, n<1000000000),求其最大公约数和最小公倍数。

  4. 输入

  5. 有多行,每行2个正整数m和n。

  6. 输出

  7. m和n的最大公约数、最小公倍数。

  8. 样例输入

  9. 16 24

  10. 5 7

  11. 样例输出

  12. 8 48

  13. 1 35

  14. 提示

  15. 要求:编写求最大公约数和最小公倍数的函数。


复制代码


这格式怎么弄呀
最佳答案
2021-11-25 15:22:15
  1. #include <stdio.h>

  2. int gcd(int m , int n)
  3. {
  4.         int d , k                                                                                     ;
  5.         if(! (m % n)) d = n                                                                           ;
  6.         else if(! (n % m)) d = m                                                                      ;
  7.         else for(d = 1 , k = 2 ; k < m && k < n ; k ++) if(! (m % k) && ! (n % k)) d = k              ;
  8.         return d                                                                                      ;
  9. }

  10. int lcm(int m , int n)
  11. {
  12.         return m * n / gcd(m , n)                                                                     ;
  13. }

  14. int main(void)
  15. {
  16.         int d[2000][2] , i , j , k , n                                                                ;
  17.         scanf("%d" , & n)                                                                             ;
  18.         for(i = 0 ; i < n ; i ++) scanf("%d%d" , & d[i][0] , & d[i][1])                               ;
  19.         for(i = 0 ; i < n ; i ++) printf("%d %d\n" , gcd(d[i][0] , d[i][1]) , lcm(d[i][0] , d[i][1])) ;
  20. }
复制代码

        编译、运行实况:
  1. D:\0002.Exercise\C>g++ -o x x.c

  2. D:\0002.Exercise\C>x
  3. 2
  4. 16 24
  5. 5 7
  6. 8 48
  7. 1 35

  8. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-11-25 15:18:47 | 显示全部楼层
用递归
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-25 15:22:15 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>

  2. int gcd(int m , int n)
  3. {
  4.         int d , k                                                                                     ;
  5.         if(! (m % n)) d = n                                                                           ;
  6.         else if(! (n % m)) d = m                                                                      ;
  7.         else for(d = 1 , k = 2 ; k < m && k < n ; k ++) if(! (m % k) && ! (n % k)) d = k              ;
  8.         return d                                                                                      ;
  9. }

  10. int lcm(int m , int n)
  11. {
  12.         return m * n / gcd(m , n)                                                                     ;
  13. }

  14. int main(void)
  15. {
  16.         int d[2000][2] , i , j , k , n                                                                ;
  17.         scanf("%d" , & n)                                                                             ;
  18.         for(i = 0 ; i < n ; i ++) scanf("%d%d" , & d[i][0] , & d[i][1])                               ;
  19.         for(i = 0 ; i < n ; i ++) printf("%d %d\n" , gcd(d[i][0] , d[i][1]) , lcm(d[i][0] , d[i][1])) ;
  20. }
复制代码

        编译、运行实况:
  1. D:\0002.Exercise\C>g++ -o x x.c

  2. D:\0002.Exercise\C>x
  3. 2
  4. 16 24
  5. 5 7
  6. 8 48
  7. 1 35

  8. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-11-25 15:25:02 | 显示全部楼层
jackz007 发表于 2021-11-25 15:22
编译、运行实况:

谢谢您!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-11-25 15:26:16 | 显示全部楼层

虽然在你们答复前我就写好了,谢谢,果然人不逼自己一把,就不知道自己能做什么
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-25 15:27:13 | 显示全部楼层
辞树 发表于 2021-11-25 15:26
虽然在你们答复前我就写好了,谢谢,果然人不逼自己一把,就不知道自己能做什么

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-25 15:31:03 | 显示全部楼层
  1. #include<stdio.h>
  2. int gcd(long x,long y){
  3.         if(y==0) return x;
  4.         return gcd(y,x%y);
  5. }
  6. int main(){
  7.         int m,n;
  8.         while(scanf("%d%d",&m,&n)==2){
  9.                 int t=gcd(m,n);
  10.                 long lcm=m/t*n;
  11.                 printf("%d %lld\n",t,lcm);
  12.         }
  13. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-25 18:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表