factors函数C语言 factorial函数c语言

C语言编程--函数的调用(判断质数 , 求最大公约数)判断质数的函数 中 在循环种定义的i 只能在循环中使用 跳出循环 还在判断 i == n 就错了
求公约数也是 。跳出循环就没有i 的定义了
简单说 就是作用域
既然三个函数都在函数中输出结果就没必要返回函数 全部换成void型
新标准main函数没有void型
用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("m",i);
k;
if(k%5==0)printf("\n");
//每五个数换一次行
}
}
getchar();
getchar();
}
你上机运行一下吧,结果是对的,有不明白的地方可以再找我……
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("]",factors[i]);
}
printf("\n\n");
printf("sum=%5ldcount=]\n",sum,count);
return 0;
}
扩展资料:
有一种说法是“因子不限正负”,不过通常情况下只取正因子 。
1, -1, n 和 -n 这些数叫做 n 的明显因子
表示方法:可以用因子|倍数或倍数≡0 (mod 因子) 来表达(参见同余),但用后者时因子一定要是正因子 。因子∣倍数 式中的垂直线是整除符号 。它的统一码值是 U 2223 。
例如 42=6x7,因此 7 是 42 的因子,写作 7∣42 , 亦是42≡0(mod 7) 。
【factors函数C语言 factorial函数c语言】关于factors函数C语言和factorial函数c语言的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读