编程介的小学生 2019-09-23 11:02 采纳率: 20.5%
浏览 421

C语言,求满足条件的最小的c

Problem Description
有三个正整数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
2
6 2
12 4

Sample Output
4
8

  • 写回答

2条回答 默认 最新

  • Mr.[数据删除] 2019-09-23 18:37
    关注

    输入n循环就不用说了。首先a,b,c之间的关系一定要理解。a与c之间的b是他们的公约数,即a=m*b;c=n*b。
    而最小值的c已知n要么是2(因为c!=b)要么因为m=2,所以n只能等于3.
    以下为代码表示

    int m;
    m=a/b;
    if(m!=2)
    c=2*b;
    else
    c=3*b;

    觉得好请给个最佳呀。orz

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?