约数的个数

Posted wangheq

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了约数的个数相关的知识,希望对你有一定的参考价值。

题目描述

输入n个整数,依次输出每个数的约数的个数

输入描述:

输入的第一行为N,即数组的个数(N<=1000)
接下来的1行包括N个整数,其中每个数的范围为(1<=Num<=1000000000)
当N=0时输入结束。

输出描述:

可能有多组输入数据,对于每组输入数据,
输出N行,其中每一行对应上面的一个数的约数的个数。
示例1

输入

复制
5
1 3 4 6 12

输出

复制
1
2
3
4
6

代码:
技术图片
#include <iostream>
#include <string>
#include <vector>
#include <cmath>
using namespace std;
int func(int num)
{
    if (num==0)
    {
        return 0;
    }
    int r = (int)sqrt(1.0 * num);
    int sum = 0;
    if (r * r == num)
    {
        sum++;
        r--;
    }
    for (int i = 1; i <= r; i++)
        if (num % i == 0)
        {
            sum += 2;
        }
    cout << sum << endl;
    return 0;

    
}
int main()
{
    int n;
    cin >> n;
    vector<int> num;
    num.resize(n);
    for (int i = 0; i < n; i++)
    {
        cin >> num[i];
    }for (int i = 0; i < n;i++)
    {
        func(num[i]);
    }
     

    return 0;
}
View Code

 

 

以上是关于约数的个数的主要内容,如果未能解决你的问题,请参考以下文章

约数的个数

约数的个数

2021-08-20P3327 [SDOI2015]约数个数和

算法笔记_160:算法提高 约数个数(Java)

算法AcWing 870. 约数个数

合约数