因子c语言
❶ c语言 因子数和
n为范围指求从1到n的完数
(k/2)是指因子的上限。
k为可能的完全数,
if(!(k%i)) m+=i; 是指如果i能够被k整除,
那i就是k的因子,
且m为所有因子的和。
if(m==k) printf("%4d",k);是指如果因子之和
等于k,则k就为完数,并输出来。
如果还有什么不懂的,可以联系我。
❷ c语言因子分解
修改如下:
//---------------------------------------------------------------------------
#include<stdio.h>
#include<conio.h>
int main()
{
int a;
void num(int n); //注意这里
while(scanf("%d",&a)!=EOF)
{
num(a); //注意这里
}
getch();
}
void num(int n) //注意这里
{
int i;
for(i=2;i<=n;i++)
{
while(n!=i)
{
if(n%i==0)
{
printf("%d ",i);
n=n/i;
}
else
{
break;
}
}
}
printf("%d",n);
}
//---------------------------------------------------------------------------
❸ C语言,求函数因子
一开始定义int m=0没必要,就是m就可以了。
循环中要定义m=0,这样,对于每一个i,m最终都得到i因子的和,然后将m与i比较,如果相等,则i是完数,输出完数i。对于下一个i,m=0的作用是将m及时恢复0,这样才能得到i因子的和,否则就是对于各个i,m的值一直累加了。
❹ C语言求完数因子
#include<stdio.h>
inta[110];
intmain()
{
intsum=0,i,n,j,sizes;
printf("输入一个数:");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
sum=0,sizes=0;
for(j=1;j<i;j++)
{
if(i%j==0)
{
sum+=j;
a[++sizes]=j;
}
}
if(sum==i)
{
printf("%disfactorsare:",i);
for(j=1;j<=sizes;j++)
printf(j==sizes?"%d. ":"%d,",a[j]);
}
}
return0;
}
开个数组储存一下因子即可。
❺ 用c语言求一个数的所有因子
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;
}
(5)因子c语言扩展阅读:
数学概念
假如整数n除以m,结果是无余数的整数,那么我们称m就是n的因子。 需要注意的是,唯有被除数,除数,商皆为整数,余数为零时,此关系才成立。反过来说,称n为m的倍数。
要留意的是:有一种说法是“因子不限正负”,不过通常情况下只取正因子。
1, -1, n 和 -n 这些数叫做 n 的明显因子
❻ 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;
}
❼ c语言 因子
#include <stdio.h>
int main()
{
int n;
printf("输入:");
scanf("%d",&n);
int factor=2;
printf("1,");
while(n>1)
{
if ( n % factor == 0)
{
printf("%d,",factor);
n = n / factor;
}
else
{
factor++;
}
}
printf("\n");
}
❽ 用C语言输出 一个整数的所有因子
main() {
int x,i;
printf("请输入一个整数:");
scanf("%d",&x);
printf("%d的因子有:", x);
for(i=1;i<=x/2;i++)
if(x%i==0)
printf("%d ",i);
printf("\n");
}
❾ 用C语言:求一个数的因子和(因子不包括自身)
#include<stdio.h>
intmain()
{
intn,i,s;
while(scanf("%d",&n)!=EOF)
{
s=1;//如果不需要包含1,可改为s=0
printf("因子列表:%d",s);
for(i=2;i<=n/2+1;i++)
{
if(n%i==0)
{
printf("%d",i);
s+=i;
}
}
printf(" 因子和:s=%d ",s);
}
return0;
}