怎么用c语言来输出一个数的因子个数

Python014

怎么用c语言来输出一个数的因子个数,第1张

设所需计算的数是N,首先N/2,若N为奇数,则(N-1)/2,然后对N/2或(N-1)/2求余,用for循环

a=N/2(若N为奇数就(N-1)/2)

for(i=1i<=ai++){

if(a%i==0)

count++;

}

最后count乘以2就行了

#include <stdio.h>

# include <stdlib.h>

#define N 100

long factor(int m,int fac[],int *cp){

int c1,c2,i,k

long s

fac[0]=1

for(c1=s=1,c2=N-1,i=2){

k=m/i

if(m%i==0){

if(i!=k){

fac[c1++]=i

fac[c2--]=k

s+=i+k

printf("i=%d k=%d\n",i,k)

}else{

fac[c1++]=i

s+=i

}

}

i++

if(i>=k) break//这个时候k已经开始等于自身的根号,或者将要出现和之前k对称的i,引起自身重复故退出

}

for(c2++c2<=N-1c2++){

fac[c1++]=fac[c2]

printf("%s %d\n","**",fac[c2])

}

*cp=c1

return s

}

int main(int argc, char const *argv[])

{

/* code */

int factors[N],i,count

long sum

sum = factor(atoi(argv[1]),factors,&count)

for(i=0i<counti++){

printf("%5d",factors[i])

}

printf("\n\n")

printf("sum=%5ld  count=%5d\n",sum,count) 

return 0

}

扩展资料:

有一种说法是“因子不限正负”,不过通常情况下只取正因子。

1, -1, n 和 -n 这些数叫做 n 的明显因子

表示方法:可以用因子|倍数或倍数≡0 (mod 因子) 来表达(参见同余),但用后者时因子一定要是正因子。因子∣倍数 式中的垂直线是整除符号。它的统一码值是 U+2223。

例如 42=6x7,因此 7 是 42 的因子,写作 7∣42,亦是42≡0(mod 7)。

#include <iostream>

using namespace std

int main()

{ int n,i,j=0,s=2

cin>>n

for(i=2i*i<ni++)

  if(n%i==0)s+=2

if(i*i==n)s++

printf("%d的因数有%d个\n",n,s)

return 0

}

==================================

#include <iostream>

using namespace std

int main()

{ int n,i,j=0,k

cin>>n

printf("%d=",n)

for(i=2i*i<=ni++)

  for(n%i==0n/=i)

    printf("%d%c",i,n>i?'*':' ')

if(n>1)printf("%d",n)

return 0

}