码迷,mamicode.com
首页 > 其他好文 > 详细

约数的个数

时间:2019-03-14 23:37:42      阅读:292      评论:0      收藏:0      [点我收藏+]

标签:end   题目   close   --   结束   board   mod   ace   sqrt   

题目描述

输入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

 

 

约数的个数

标签:end   题目   close   --   结束   board   mod   ace   sqrt   

原文地址:https://www.cnblogs.com/hequnwang/p/10534369.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!