zoj 1539 Lot

/*理解题意后,发现最后剩下的都是个数并不是和奇数偶数等有直接的关系,所以我们直接从数量入手

比如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;

        }

    }

}

 

你可能感兴趣的:(ZOJ)