c语言求函数因子定义 c语言中怎样求一个数的因子

C语言:编写一个函数,求出一个给定数字的所有因子。

1.对1~本身的各个数取余,为零的即为其因子。

建网站原本是网站策划师、网络程序员、网页设计师等,应用各种网络程序开发技术和网页设计技术配合操作的协同工作。创新互联专业提供网站设计、成都网站设计,网页设计,网站制作(企业站、成都响应式网站建设、电商门户网站)等服务,从网站深度策划、搜索引擎友好度优化到用户体验的提升,我们力求做到极致!

#include stdio.h

void factor(int n)

{

printf("%d factor has: ", n);

for (int i = 1; i = n; i ++)

{

if (n % i == 0)

printf("%d ", i);

}

printf("\n");

}

int main()

{

factor(27);

factor(100);

return 0;

}

c语言求一个数的因子

#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-1;c2++){

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=0;icount;i++){

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)。

C语言,先定义判断是否为素数的函数,然后求其质因子

1.#include stdio.h

int fun(int n)

{

int i;

if(n == 2)

{

printf("是素数\n");

return 0;

}

else if(n = 1)

{

printf("不是素数\n");

return 0;

}

else

{

for(i = 2;i = n/2; i++)

{

if(n % i == 0)

{

printf("不是素数\n");

break;

}

}

if(i == (n/2+1) )

{

printf("是素数\n");

}

}

}

int main()

{

int n;

scanf("%d",n);

fun(n);

}

2.#include stdio.h

int main()

{

int a[10],i,sum=0,max,min;

for(i = 0; i 10; i++ )

{

scanf("%d",a[i]);

}

max=a[0];

min=a[0];

for(i = 1;i = 9;i++)

{

if(maxa[i])

{

max=a[i];

}

}

for(i = 1;i = 9;i++)

{

if(mina[i])

{

min=a[i];

}

}

for(i = 0;i = 9;i++)

{

sum=sum+a[i];

}

sum=sum-max-min;

printf("最终得分为:%d\n",sum);

return 1;

}

3.-102的原码是11100110

反码是10011001

补码是10011010

4.#include stdio.h

int main()

{

int i,n;

int s=1;

scanf("%d",n);

if(n0)

{

return 0;

}

if(n==0)

{

printf("%d的阶乘是:1\n",n);

return 0;

}

for(i=1;i=n;i++)

s=s*i;

printf("%d的阶乘是:%d\n",n,s);

return 0;

}

C语言求因数

#includemath.h

int

fun(int

n)

{int

i,k=1;

for(i=2;i=sqrt(n);i++)

if(n%i==0)

k=0;

return

k;}

void

factor(int

n)

{

int

i,x,m=n;

printf("\n%d=",n);

for(i=2;i=n;i++)

{

if(fun(i)==1m%i==0){

printf("%d*",i);

m=m/i;

i=1;

if(fun(m)==1)

break;}

}

printf("%d\n",m);

}

main()

{

int

a;

printf("shu

ru

yi

ge

shu:");

scanf("%d",a);

factor(a);

}

因为一定要是素因数的乘积

所以我多用了一个判断是不是素数的函数,可以不?

如果只能用一个函数,你就自己把fun函数放进去,不过写起来就有点繁了!

C语言,求函数因子

一开始定义int m=0没必要,就是m就可以了。

循环中要定义m=0,这样,对于每一个i,m最终都得到i因子的和,然后将m与i比较,如果相等,则i是完数,输出完数i。对于下一个i,m=0的作用是将m及时恢复0,这样才能得到i因子的和,否则就是对于各个i,m的值一直累加了。


网站栏目:c语言求函数因子定义 c语言中怎样求一个数的因子
URL分享:http://cdiso.cn/article/dodogpd.html

其他资讯