-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdiv.cpp
More file actions
57 lines (52 loc) · 1.11 KB
/
div.cpp
File metadata and controls
57 lines (52 loc) · 1.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include<iostream>
#include<math.h>
#include<string.h>
#include<algorithm>
#include<stdio.h>
#include<vector>
#define Max 1000000
using namespace std;
#define FRO freopen("in.txt","r",stdin);
int prime_int[Max];
bool prime_bool[Max];
void prime_num()
{
int i,j,root=sqrt(Max);
for(i=4;i<=Max;i+=2)prime_bool[i]=true;
for(i=3;i<=root;i+=2)if(!prime_bool[i])
{
for(j=i*i;j<=Max;j+=2*i)prime_bool[j]=true;
}
prime_int[0]=2;
for(i=3,j=1;i<Max;i+=2)if(!prime_bool[i])prime_int[j++]=i;
}
vector<int> div(int num)
{
vector<int>divisor;
int i,root=sqrt(num),pr;
for(i=1;i<=root;i++)
{
if(num%i==0&& num/i!=num)
{
pr=i;
divisor.push_back(pr);
if(num/i!=i)divisor.push_back(num/i);
}
}
return divisor;
}
int main()
{
//FRO
int b,c,i,j,k,tc,t,n,size;
prime_num();
while(scanf("%d",&n)!=EOF)
{
vector<int> divisor=div(n);
size=divisor.size();
printf("Divisor(s) of %d:\n",n);
for(i=0;i<size;i++)printf("%d ",divisor[i]);
printf("\nGive another number:");
}
return 0;
}