SG_WGL 2017-11-05 14:20 采纳率: 50%
浏览 1027
已采纳

代码超时,求一个优化的思路。。。

如果从整数区间[1,a]内取一个整数x, 从整数区间[1,b]内取一个整数y, 要求x和y的最大公约数为k.
问满足要求的(x,y)有多少对。规定(x,y)和(y,x)不重复计数。

例如分别从[1,3]和[1,5]区间取x和y, 则最大公约数为1的对为:
(1,1),(1,2),(1,3),(1,4),(1,5),(2,3),(2,5),(3,4),(3,5)
共9对
输入描述

输入3个整数a,b,k

输出描述

满足要求的(x,y)对的数目

输入样例

3 5 1

输出样例

9

#include<stdio.h>

int gcd(int m, int n) {
    int r = 0;
    while (n) {
        r = m % n;
        m = n;
        n = r;
    }
    return m;
}

int main() {
    int a;
    int b;
    int k;
    scanf_s("%d%d%d", &a, &b, &k);
    int count = 0;
    for (int i = 1; i <= (a<b ? a : b); i++) {
        for (int j = i; j <= (a>b ? a : b); j++) {
            if (gcd(i, j) == k) {
                count++;
            }
        }
    }
    printf("%d", count);
}

上面是我的代码,但是会超时...没什么好的思路,求指点

  • 写回答

3条回答 默认 最新

  • Leonhard_l 2017-11-05 14:32
    关注

    1.求最大公约数用辗转相减 2.在for循环中加入一条if(i%k==0&&j%k==0) 3.i从k开始循环

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 深度学习残差模块模型
  • ¥20 两个不同Subnet的点对点连接
  • ¥50 怎么判断同步时序逻辑电路和异步时序逻辑电路
  • ¥15 差动电流二次谐波的含量Matlab计算
  • ¥15 Can/caned 总线错误问题,错误显示控制器要发1,结果总线检测到0
  • ¥15 C#如何调用串口数据
  • ¥15 MATLAB与单片机串口通信
  • ¥15 L76k模块的GPS的使用
  • ¥15 请帮我看一看数电项目如何设计
  • ¥23 (标签-bug|关键词-密码错误加密)