c语言自定义求阶函数例子 自定义函数阶乘

C语言设计:定义一个求阶乘的函数,然后计算1!-2!+3!-4!+5!-6!+7!-8!+9!.

#include "stdio.h"

为黄埔等地区用户提供了全套网页设计制作服务,及黄埔网站建设行业解决方案。主营业务为网站设计、成都网站制作、黄埔网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

double fun(int n)//用double提高精度和计数位数。

{

double sum=1.0;

int i;

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

     sum*=i;

return sum;

}

int main()

{

 int i,mark=1;

 double sum=0,item=0;

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

 {

      item=mark*fun(i);

      sum+=item;

      mark=-mark;

 }

 printf("1!-2!+3!-4!+5!-6!+7!-8!+9!=%.0lf\n",sum);

}

c语言 编程实现求n!要求用定义求阶乘的函数

1、打开vs2017软件,新建c语言的工程,首先开头引入头文件,然后调用先调用一下求阶乘的函数和空的主函数,最下方定义prime函数用来求阶乘:

2、主函数中用scanf函数接受用户输入的的数字,接着将输入的数传入处理阶乘的函数中完成计算,最后输出打印结果。prime函数有一个参数,首先判断是否为正数,然后用prime函数自身乘以参数s,最后返回值即可完成:

3、将程序编译运行,弹出窗口输入任意的数,计算阶乘;这里输入7,得到结果是5040。以上就是C语言求阶乘的方法:

C语言:自定义求阶乘函数,主函数调用该函数计算1!+2!+3!+4!+5!值,咋编?

代码文本:

#include "stdio.h"

int myfact(int n){

return n1 ? n*myfact(n-1) : 1;

}

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

int i,s;

for(s=0,i=1;i6;s+=myfact(i++));

printf("1!+2!+3!+4!+5! = %d\n",s);

return 0;

}

c语言求阶乘的函数

阶乘:

阶乘是基斯顿·卡曼(Christian

Kramp,1760~1826)于

1808

年发明的运算符号,是数学术语。

一个正整数的阶乘(英语:factorial)是所有小于及等于该数的正整数的积,并且有0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。

亦即n!=1×2×3×...×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。

C语言

C

语言中,使用循环语句可以很方便的求出阶乘的值,下面介绍一个很简单的阶乘例子。(因为网上多数是比较麻烦的方法)

【计算出“

1!+

2!+

3!+

……

+

10!”的值是多少?】

#includestdio.h

int

main()

{

int

x;

long

j=1,sum=0;

for(x=1;x=10;x++)

{

j*=x;

sum+=j;

}

printf("1!+2!+...+10!=%ld\n",sum);

return

0;

}

/*结果:4037913*/

Pascal中program

test;

varn:longint;

function

jc(n:longint):qword;

begin

if

n=0

then

jc:=1

else

jc:=n*jc(n-1)end;

begin

readln

(n);

writeln

(jc(n))end.

C++

#includeiostream

using

namespace

std;

long

long

f(int

n)

{

long

long

e=1;

if(n0)

e=n*f(n-1);

coutn"!="eendl;

return

e;

}

int

main()

{

int

m=20;

f(m);

return

0;

}

以上使用

C++

11

标准

也可以利用积分求浮点数阶乘:

#includecstdio

#includecmath

double

s;

const

double

e=exp(1.0);

double

F(double

t)

{

return

pow(t,s)*pow(e,-t);

}

double

simpson(double

a,double

b)

{

double

c=a+(b-a)/2;

return

(F(a)+4*F(c)+F(b))*(b-a)/6;

}

double

asr(double

a,double

b,double

eps,double

A)

{

double

c=a+(b-a)/2;

double

L=simpson(a,c),R=simpson(c,b);

if(fabs(L+R-A)=15*eps)

return

L+R+(L+R-A)/15.0;

return

asr(a,c,eps/2,L)+asr(c,b,eps/2,R);

}

double

asr(double

a,double

b,double

eps)

{

return

asr(a,b,eps,simpson(a,b));

}

int

main()

{

scanf("%lf",s);

printf("%lf\n",asr(0,1e2,1e-10));

return

0;

}

C语言设计一个函数求阶乘

1

设计阶乘函数。

按照数学定义,对于n的阶乘,如果n为0,则返回1.

否则返回1*2*3*...*n的值。用循环实现。

2

在主函数中输入要求阶乘的值。

3

调用函数计算阶乘。

4

输出结果。

代码:

int fac(int n)

{

int r = 1;

int i;

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

r*=i;

return r;

}

int main()

{

int n,r;

scanf("%d",n);

r = fac(n);

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

}

C语言编写一个求n阶乘的函数,在主函数中输入n,调用函数求n阶乘。。谢谢

//因C语言数据类型限制,不能做大数的阶乘运算

//n的值超过22结果会不准确

#include stdio.h

double jc( int n )

{

int i;

double rs=1 ;

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

rs *= i ;

return rs ;

}

int main()

{

int n;

printf("input n:");

scanf("%d" , n );

printf("%d!=%.0lf\n" , n, jc(n) );

return 0;

}


网页名称:c语言自定义求阶函数例子 自定义函数阶乘
URL网址:http://myzitong.com/article/dooiech.html