HDU2047 阿牛的EOF牛肉串

本文详细介绍了如何通过排列组合的方法解决一道特定数学问题,并且解决了在使用pow函数时遇到的测试网站编译器不支持__int64导致的错误。通过实践案例分享了在编程中遇到的挑战及其解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天帮学弟看了下这道题

顺便学习了一下学弟的思路

先对不是o的算出排列数,然后用o进行插入,插入的时候不用管原来的位置是怎样的,只需要保证两个数之间只插一个o。想了很久才想清楚

再说下学弟的问题,因为用到了pow函数,可能是测试网站编译器的pow函数不支持__int64,所以老错,后来终于找出原因了

#include<stdio.h>
__int64 s(__int64 a,__int64 n){
	__int64 i;
	__int64 m=1;
	for(i=0;i<n;i++)
		m=m*(a-i)/(i+1);
	return m;
}
__int64 pow(__int64 a,__int64 b){
    __int64 s=1;
    for(int i=1;i<=b;i++) s*=a;
    return s;
}
int main()
{
    #ifndef ONLINE_JUDGE
    freopen("in.txt","r",stdin);
    #endif // ONLINE_JUDGE
      __int64 m;
    __int64 n,i,j;
	  while(scanf("%I64d",&n)!=EOF)
	  {
		  j=n%2+n/2;
		  m=pow(2,n);
		  for(i=1;i<=n;i++)
			  m+=s(n-i+1,i)*pow(2,n-i);
		   printf("%I64d\n",m);

	  }
	  return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值