当前位置:首页 » 编程语言 » C语言中如何计算因子
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

C语言中如何计算因子

发布时间: 2022-11-27 00:14:43

1. c语言 因子计算

你这里最主要的错误就是t==0,应该是t=0这样才是赋值
另外,你的输出不应该放在循环外面,还按你的模板把这两个改一下应该就能对了
也就是
#include<stdio.h>
#include<stdlib.h>
int main()
{
int i,t,n;
t=0; //就是这里要用=,==是用来判断是否相等的
scanf("%d",&n); //n为要判断的数
for(i=1;i<n;i++){
if(n%i==0)
t=i+t; //求这个数个各因子的和
}
if(t==n) //如果相等的话,要放在循环外,这样t才是所有因子的和
printf("%d",n); //打印这个数
system("pause");
return 0;
}
但是你这个程序仅仅是判断一个数n是不是完数,你给的题的意思好像要判断n以内所有的
那就要这样
#include<stdio.h>
#include<stdlib.h>
int main()
{
int i,j,t,n;
scanf("%d",&n); //n为要判断的数
for(i=1;i<=n;i++){ //此时遍历的i不为求因子,而为判断i是不是完数,这个循环内的模板与上一个程序是类似的
t=0;
for(j=1;j<i;j++)//求这个数个各因子的和,此时j用来判断是不是因子
{
if(i%j==0)
t=j+t;
}
if(i==t) //如果相等的话
printf("%d\n",i); //打印这个数,这时要一个\n回车,以区分各数
}

system("pause");
return 0;
}

2. 用C语言:计算并输出给定整数N的所有因子(不包括1与自身)之和

思路:输入一个数n,接着for循环从2到n-1依次整除n,如果能被整除则累加,最后输出累加和。

参考代码:

#include<stdio.h>
intmain()
{
intn,i,sum=0;
scanf("%d",&n);
for(i=2;i<n;i++)
if(n%i==0)
sum+=i;
printf("累加和为:%d ",sum);
return0;
}
/*
6
累加和为:5
*/

3. C语言:编写函数,计算出形参n的所有因子之和(包括1与自身)

#include "stdio.h"

int fun(int n)

{int i,s=n+1;

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

if(n%i==0)s+=i+n/i;

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

return s;

}

main()

{ int k;

scanf("%d",&k);

printf("%d ",fun(k));

}

4. 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 ",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 ","**",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;i<count;i++){

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

}

printf(" ");

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

return 0;

}

(4)C语言中如何计算因子扩展阅读:

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

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

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

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



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

设所需计算的数是N,首先N/2,若N为奇数,则(N-1)/2,然后对N/2或(N-1)/2求余,用for循环
a=N/2(若N为奇数就(N-1)/2)
for(i=1;i<=a;i++){
if(a%i==0)
count++;
}
最后count乘以2就行了

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

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

#include<stdio.h>

voidfactor(intn)
{
printf("%dfactorhas:",n);
for(inti=1;i<=n;i++)
{
if(n%i==0)
printf("%d",i);
}
printf(" ");
}

intmain()
{
factor(27);
factor(100);
return0;
}

7. c++ 中求一个数的因子,因子是什么

  1. 因子:基本含义为“元素、因素、成分”,一般在编程中,因子指因数。

  2. 因数:假如a÷b=c(a、b、c都是整数),那么我们称b和c就是a的因数。 需要注意的是,唯有被除数,除数,商皆为整数,余数为零时,此关系才成立。

  3. C++ 中求一个数 N 的因数的算法:

    for(i=1;i<=N;i++)//从1枚举到N
    if(N%i==0)cout<<i<<endl;//如果N能被i整除,i就是一个因数

8. c语言编程:求一个数的质因子

#include<stdio.h>
intmain()
{
inti,j,a[999999],x,y;
scanf("%d",&x);//读取
y=x;
for(i=2,j=0;i<=x;i++)//遍历质因数
{
if(x%i==0)//如果读取的数能够被质因数整除
{
a[j]=i;//将符合条件的质因数存到数组中
j++;//数组下标递增
x/=i;//重新赋值
i=2;//重新遍历
}
}
printf("%d=%d",y,a[0]);//输出原数、等号、第一个质因数
for(i=1;i<j;i++)
printf("×%d",a[i]);//如果存在第二个质因数,则继续输出
return0;
}

9. C语言,求函数因子

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

10. 用C语言编写一个函数factors,求出一个正整数的所有因子。

#include

#include
//数学函数头文件
main()
{
int
m,i,k=0;
printf("请你输入一个正整数:\n");
scanf("%d",&m);
printf("%d
的因子有:\n",m);
for(i=1;i<=m;i++)
{
if(m%i==0)
{
printf("%6d",i);
k++;
if(k%5==0)printf("\n");
//每五个数换一次行
}
}
getchar();
getchar();
}
你上机运行一下吧,结果是对的,有不明白的地方可以再找我……