x*y的所有因数=x的所有因数分别乘以y的所有因数

例题C-小红的因子幂和_牛客周赛 Round 143(重现赛)

思路:

我们先分别求出x,y的所有因子,接着用一个集合来存储x*y的所有因数,也就是x的所有因数分别乘以y的所有因数,然后用ksm求值便可

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define endl "\n"
#define int  long long
const int mod = 1e9 + 7;
int q_mul(int n, int x) {
    int res = 1;//累乘变量
    n %= mod;
    while (x != 0) {//只要x不为0就始终执行下去
        if (x % 2 == 1)res =res*n%mod;//当前的2进制位为1,乘上当前位置的n,即我们的任务2
        x /= 2;//x除以2,和短除法一样
        n =n*n%mod;//n每次乘以自身,即我们的任务1
    }
    return res;
}
vector<int> isp(int n) {
    vector<int>v;
    for (int i=1;i*i<=n;i++) {
        if (n%i==0) {//判断i是不是n的因子(可以整除就是)
            v.push_back(i);
            if (i!=n/i) {//与i成对的因子
                v.push_back(n/i);
            }
        }
    }
    return v;
}
void solve() {
    int x,y;
    cin >> x >> y;
    vector<int>a=isp(x);
    vector<int>b=isp(y);
    set<int>s;
    for (int i=0;i<a.size();i++) {
        for (int j=0;j<b.size();j++) {
            s.insert(a[i]*b[j]);
        }
    }
    int ans=0;
    for (auto it=s.begin();it!=s.end();it++) {
        ans=(ans+q_mul(*it,*it))%mod;
    }
    cout << ans << endl;
}

signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int T=1;
    //cin >> T;
    while (T--)
        solve();
    return 0;
}
相关推荐
计算机安禾1 小时前
【c++面向对象编程】第7篇:static成员:属于类而不是对象的变量和函数
java·c++·算法
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第47题】【JVM篇】第7题:Young GC 和 Full GC 分别采用什么算法?
java·jvm·后端·算法·面试
Ulyanov1 小时前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 同台竞技——3-DOF与6-DOF模型的终极对决与误差分析
开发语言·python·算法·系统仿真·雷达电子对抗仿真
Hesionberger1 小时前
LeetCode98:验证二叉搜索树(多解)
java·开发语言·python·算法·leetcode·职场和发展
千寻girling1 小时前
周日那天参加的力扣周赛... —— 10号
java·javascript·c++·python·算法·leetcode·职场和发展
guygg881 小时前
基于 DWT 的盲数字水印实现(嵌入与提取)
算法
鱼子星_1 小时前
最短路问题【图论】
数据结构·算法·贪心算法·动态规划·图论
研究点啥好呢1 小时前
dji机器人SLAM算法工程师 面试题精选:10道高频考题+答案解析
c++·算法·机器人·slam·dji
君万1 小时前
【LeetCode每日一题】3. 无重复字符的最长子串 560. 和为 K 的子数组
算法·leetcode·golang·go