Oi_oier 2021-08-26 00:38 采纳率: 83.3%
浏览 100
已结题

一道递归的题,有哪位可以解决一下我的bug!

题目描述
圣诞节本节,阿杰决定在自己的聚会上制作一个多维汉堡。
对于一个 L 级汉堡:0级汉堡是肉,L汉堡 (L≥1) 由方包,(L−1) 级汉堡,肉饼,(L−1) 级汉堡和另一个方包,从底部开始按此顺序垂直堆叠而成。
例如:一级汉堡和二级汉堡看起来像 01110 和0011101011100(旋转 90 度),其中 0 代表方包, 1 代表肉饼。
阿杰将制作的汉堡为 N级汉堡包,从这个汉堡的底部往上吃共 X 层(一层是肉饼或方包)。
请问他能吃到多少快肉饼?

输入格式
两个正整数,N 和 X 。

输出格式
一个正整数,代表阿杰能吃到的馅饼数量。

样例输入
2 7
样例输出
4
数据范围
对于 100% 的数据:0<L 1≤N≤50,X 小于总层数 。
下面是我的代码,主要是不知道怎么把总汉堡样子(a)给弄出来

#include<bits/stdc++.h>
using namespace std;
long long a;
int x,n,sum=1;
int tongji(int a){
    int cnt=0;
    while(a>0){
        a/=10;
        cnt++;
    }
    return cnt;
}
long long hb(int n){               
    if(n==1){
        //printf("01110");       
        a+=01110*pow(10,sum);         
        sum+=6;

    }
    else{
        hb(n-1);
        a+=1*pow(10,tongji(hb(n-1))+1);
        hb(n-1);
    }
    return a;
}
int main(){
    scanf("%d",&x);
    printf("%lld",hb(x));
    return 0;
}

  • 写回答

2条回答 默认 最新

  • 关注

    a+=01110*pow(10,sum);有问题, 01110 是0开头的数值是八进制,并且a数值位数太大的话就是long long也放不下 ,,应该用数组保存 。

    你题目的解答代码如下:(如有帮助,望采纳!谢谢! 点击我这个回答右上方的【采纳】按钮)

    #include<bits/stdc++.h>
    using namespace std;
    int a[1000];
    int x,n,len=0;
    void hb(int n){
        if(n==0){
            a[len++] = 1;//肉饼
        }
        else{
            a[len++] = 0;//方包
            hb(n-1); //(L−1) 级汉堡
            a[len++] = 1;//肉饼
            hb(n-1); //(L−1) 级汉堡
            a[len++] = 0;//方包
        }
    }
    int main(){
        scanf("%d",&x);
        hb(x);
        for(int i=0;i<len;i++)
            printf("%d", a[i]);
    
        return 0;
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月3日
  • 已采纳回答 8月26日
  • 创建了问题 8月26日

悬赏问题

  • ¥50 求解vmware的网络模式问题
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?