鱼C论坛

 找回密码
 立即注册
查看: 1096|回复: 3

[已解决]核桃的数量

[复制链接]
发表于 2020-11-29 17:55:07 | 显示全部楼层 |阅读模式

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

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

x
小张是软件项目经理,他带领3个开发组。工期紧,今天都在加班呢。为鼓舞士气,小张打算给每个组发一袋核桃(据传言能补脑)。他的要求是:

1. 各组的核桃数量必须相同

2. 各组内必须能平分核桃

3.满足1,2的最小数量

输入描述:

输入包含三个正整数a, b, c,表示每个组正在加班的人数,用空格分开(a,b,c<30)

输入样例:2 4 5
输出样例:20

最佳答案
2020-11-29 19:09:51

建议改为
  1. int gcd(int a, int b) {
  2.     int c;

  3.     while (b) {
  4.         c = a % b;
  5.         a = b;
  6.         b = c;
  7.     }

  8.     return a;
  9. }


  10. int lcm(int a, int b) {
  11.     return a * b / gcd(a, b);
  12. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-29 18:12:11 | 显示全部楼层
本帖最后由 小甲鱼的铁粉 于 2020-11-29 19:23 编辑
  1. #include <stdio.h>
  2. //求最小公倍数
  3. int gcd(int a, int b)
  4. {
  5.     int c;

  6.     while (b)
  7.    {
  8.         c = a % b;
  9.         a = b;
  10.         b = c;
  11.     }

  12.     return a;
  13. }


  14. int lcm(int a, int b)
  15. {
  16.     return a * b / gcd(a, b);
  17. }
  18. int main()
  19. {
  20.         int a,b,c;
  21.         scanf("%d%d%d",&a,&b,&c);
  22.         int result1 = lcm(a,b);
  23.         int result2 = lcm(a,c);
  24.         int result3 = lcm(result1,result2);
  25.         printf("%d",result3);
  26. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-29 19:09:51 | 显示全部楼层    本楼为最佳答案   

建议改为
  1. int gcd(int a, int b) {
  2.     int c;

  3.     while (b) {
  4.         c = a % b;
  5.         a = b;
  6.         b = c;
  7.     }

  8.     return a;
  9. }


  10. int lcm(int a, int b) {
  11.     return a * b / gcd(a, b);
  12. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-11-29 19:23:50 | 显示全部楼层

这个确实快,牛逼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-12 19:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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