编程求组合

None.gif #include  < stdio.h >
None.gif#include 
< conio.h >
None.gif
long  fac( int );
None.gif
long  comb( int  n, int  m);
None.gif
void  main()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
int n,m;
InBlock.gif 
long result;
InBlock.gif clrscr();
InBlock.gif scanf(
"%d,%d",&n,&m);
ExpandedSubBlockStart.gifContractedSubBlock.gif result
=comb(n,m);          /**//*调用组合函数*/
InBlock.gif printf(
"%ld",result);
ExpandedBlockEnd.gif}

None.gif
ExpandedBlockStart.gifContractedBlock.gif
long  fac( int  k)              /**/ /*定义阶乘的函数*/
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
long f=1;
InBlock.gif 
for (int i=1;i<=k;i++)
InBlock.gif   f
=f*i;
InBlock.gif 
return f;
ExpandedBlockEnd.gif}

None.gif
ExpandedBlockStart.gifContractedBlock.gif
long  comb( int  n, int  m)      /**/ /*定义组合函数*/
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
long c;
ExpandedSubBlockStart.gifContractedSubBlock.gif c
=fac(m)/(fac(n)*fac(m-n));    /**//*嵌套调用阶乘函数*/
InBlock.gif 
return c;
ExpandedBlockEnd.gif}


None.gif #include < stdio.h >
None.gif#include
< conio.h >
None.gif
long   int  pq( long   int  n)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
if(n==0||n==1)return 1;
InBlock.gif 
else
InBlock.gif  
return n*pq(n-1);
ExpandedBlockEnd.gif}

None.gif
void  main()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif 
long int m,n;
InBlock.gif printf(
"Please input the value of m,n(m>=n>=0):");
InBlock.gif scanf(
"%ld,%ld",&m,&n);
InBlock.gif 
if(m<n||m<0||n<0)
InBlock.gif     printf(
"Error!\n");
InBlock.gif 
else
InBlock.gif     printf(
"The result is:%ld\n",pq(m)/pq(m-n)/pq(n));
ExpandedBlockEnd.gif}

None.gif

转载于:https://www.cnblogs.com/qixin622/archive/2007/01/14/619893.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值