直接法

参考代码:

#include<bits/stdc++.h>
using namespace std;

int factor(int n){
    int s=0;
    for(int i=1;i<=n/2;i++) {
        if(n%i==0) 
			s+=i;
    }
    return s;
}
int main() {
	int a,b;
	cin>>a>>b;
	if(factor(a)==b && factor(b)==a)
		cout<<"yes";
	else
		cout<<"no";
	return 0;
}

运行情况:

屏幕截图 2021-04-18 012152.png



约数和定理法

2 012439.png

参考代码:

#include<bits/stdc++.h>

using namespace std;

int ysh(int a) {
	if(a<4) return 0;
	int count=1;
	vector<int> sign(a,1);
	int n=a;
	
	for(int i=2; i<a; ++i) {
		if(sign[i]) {
			//线性筛
			for(int j=2*i; j<n; j=j+i) {
				sign[j]=0;
			}
			//分解质因数(i,num) i^num*…… 
			if(n%i==0) {
				int num=0;
				while(n%i==0) {
					n=n/i;
					++num;
				}
				//约数和定理f(n)=(p1^0+p1^1+p1^2+)(p2^0+p2^1+p2^2+)……
				int sum=1;
				while(num) {
					int numi=num;
					int s=1;
					while(numi) {
						s*=i;
						--numi;
					}
					sum+=s;
					--num;
				}
				count*=sum;
				if(n==0)
					break;
			}
		}
	}
	return count-a;
}

运行情况:

屏幕截图 20212726.png

屏.png

点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论