acgo题库
  • 首页
  • 题库
  • 题单
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情题解(0)讨论(0)提交记录(0)
  • 题解

    很明显 kkk 是 A,BA,BA,B 的公约数,也就是 gcd⁡(A,B)\gcd(A,B)gcd(A,B) 的约数,直接枚举即可。要注意约数成对出现,所以复杂度为 O(gcd⁡(A,B)O(\sqrt{\gcd(A,B})O(gcd(A,B ). Code:

    userId_undefined

    亚洲卷王 AK IOI

    尊贵铂金
    54阅读
    0回复
    0点赞
  • 题解

    递归,辗转相除法

    userId_undefined

    zsy

    秩序白银
    36阅读
    0回复
    1点赞
  • 题解

    #include <bits/stdc++.h> using namespace std; int gcd(int a, int b) { while (b != 0) { int temp = b; b = a % b; a = temp; } return a; } int main() { int A, B; cin >> A >> B; int g = gcd(A, B); vector<int> divisors; for (int i = 1; i * i <= g; ++i) { if (g % i == 0) { divisors.push_back(i); if (i != g / i) { divisors.push_back(g / i); } } } sort(divisors.begin(), divisors.end()); for (int k : divisors) { cout << k << " "; } return 0; }

    userId_undefined

    霄

    荣耀黄金
    2阅读
    0回复
    0点赞
首页