求取约数的个数的算法

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_36561697/article/details/97406920
/*https://www.nowcoder.com/practice/04c8a5ea209d41798d23b59f053fa4d6?tpId=40&tqId=21334&tPage=1&rp=1&ru=%2Fta%2Fkaoyan&qru=%2Fta%2Fkaoyan%2Fquestion-ranking*/

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

void printnum(int num){
	int n = sqrt(num);
	int count = 0;
	if(n * n == num){
		count++;
		n--;
	}
	for (int i = 1; i <= n; ++i){
		if(num % i == 0)
			count += 2;
	}
	printf("%d\n", count );
}

int main(int argc, char const *argv[]){
	int n,num;
	scanf("%d",&n);
	for (int i = 0; i < n; ++i){
		scanf("%d",&num);
		printnum(num);
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_36561697/article/details/97406920