第十四周训练总结(二)

这几天重点看了一下容斥原理。容斥原理,在高中学过一点,但是用来解题的话,还是有障碍,特别是不知道怎么写代码。

容斥原理的想法就是求多个集合的并集.所以要先设计好集合组合数学问题中,正面解决会困难,常用方法是正难则反,使用容斥原理求反向在用全集减去.将对立面的限制条件分析清楚例如求区间互质的数的个数,则用除法等计算出一个数的倍数的方法再减去

容斥原理的常见代码写法DFS法

模板:
  1. #include<iostream>  
  2. #include<algorithm>  
  3. #include<cstdio>   
  4. #include<iomanip>  
  5. using namespace std;  
  6. #define out(x) cout<<#x<<": "<<x<<endl  
  7. const double eps(1e-8);  
  8. const int maxn=10100;  
  9. const long long maxint=-1u>>1;  
  10. const long long maxlong=maxint*maxint;  
  11. typedef long long lint;  
  12. int n;  
  13. double p[maxn],ans;  
  14.   
  15. void init()  
  16. {  
  17.     for (int i=1; i<=n; i++)  
  18.         cin>>p[i];  
  19. }  
  20.   
  21. void dfs(int x, int tot, double sum)  
  22. {  
  23.     if (x==n+1)  
  24.     {  
  25.         if (sum==0.0) return;//divide by zero is illegal  
  26.         if (tot&1)  
  27.             ans+=1/sum;  
  28.         else  
  29.             ans-=1/sum;  
  30.         return;  
  31.     }  
  32.     dfs(x+1,tot,sum);  
  33.     dfs(x+1,tot+1,sum+p[x]);  
  34. }      
  35.   
  36. void work()  
  37. {  
  38.     ans=0;  
  39.     dfs(1,0,0.0);  
  40.     printf("%.4f\n",ans);  
  41. }  
  42.   
  43. int main()  
  44. {  
  45.     while(cin>>n)  
  46.     {  
  47.     init();  
  48.     work();  
  49.     }  
  50.     return 0;  
  51. }  



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值