poj1953 排列组合(插空法)

该博客主要介绍了如何解决POJ1953问题,即求解n位二进制数中不包含相邻1的数量。通过解析题意,博主提出使用插空法进行解题,指出当0的个数为a,1的个数为b(a+b=n,a>=b)时,存在a+1个空位用于放置1。博客还提及了代码实现时的注意事项,即计算结果需谨慎选择数据类型,否则可能导致错误。
摘要由CSDN通过智能技术生成

题意

给出一个数n,求n位二进制中有多少个数不包含相邻的1

解题思路

采用插空法
1. 对于n位二进制数,不包含相邻的1时,1的个数必定不大于0的个数。
2. 假设0的个数为a,1的个数为b,(a+b=n,且a>=b)则产生a+1个空位来放置1。

代码

注意:若用long long存储计算结果会WA

#include <stdio.h>
#include <stdlib.h>
double sum,a,b;
int main()
{
    int n,t;
    int i,j,k,l;
    scanf("%d",&t);
    for(i=1;i<=t;i++){
        scanf("%d",&n);
        
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值