首页 > 其他 > 详细

zoj 1539 Lot

时间:2014-03-10 23:54:48      阅读:696      评论:0      收藏:0      [点我收藏+]
bubuko.com,布布扣
/*理解题意后,发现最后剩下的都是个数并不是和奇数偶数等有直接的关系,所以我们直接从数量入手
比如11会被分为5,6.5再分2,3.6再分3,3只要剩下三个就算一种,少于三个不用算。大于3个继续分
很简单,这里循环处理还涉及到分支循环,类似于二叉树。这种情况明显用递归 
*/ 
#include<string.h>
#include<stdio.h>
int zb(int);
int main(int argc, char* argv[])
{

    int n,i,count;
    while(scanf("%d",&n)!=EOF)
    {
        count=zb(n);
        printf("%d\n",count);
    }

    return 0;
}
int zb(int n)
{
    if(n==3)/*终止条件*/ 
        return 1;
    else if(n<3)
        return 0;
    else
    {
        if(n%2==1)/*分支递归*/ 
        {
            return zb(n/2)+zb((n+1)/2);
        }
        else
        {
            return zb(n/2)*2;
        }
    }
}
bubuko.com,布布扣

zoj 1539 Lot,布布扣,bubuko.com

zoj 1539 Lot

原文:http://www.cnblogs.com/woshijishu3/p/3592668.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!