MagicianY.L 2015-12-19 03:46 采纳率: 66.7%
浏览 1967
已采纳

为什么最后输出结果会是0?当被调函数中的if语句不成立时不想要它返回该如何?

#include<stdio.h>

char a[15];
int count=0;

int fun(int store,int flower,int wine,int i)
{
    if(store>5 || flower>10)
        return 0;
    else if(store==5 && flower==10 && i==15)
    {
        if(wine==0 && a[14]=='b')
        {
            count++;
        }
    }
    a[i]='a';
    fun(store+1,flower,wine*2,i+1);
    a[i]='b';
    fun(store,flower+1,wine-1,i+1);
    return count;
}

void main()
{
    printf("%d\n",fun(0,0,2,0));
} 
    题目描述:

话说大诗人李白,一生好饮。幸好他从不开车。 无事街上走,提壶去打酒。
逢店加一倍,遇花喝一斗。
这一路上,他一共遇到店5次,遇到花10次,已知最后一次遇到的是花,他正好把酒喝光了。

请你计算李白遇到店和花的次序,可以把遇店记为a,遇花记为b。则:babaabbabbabbbb 就是合理的次序。像这样的答案一共有多少呢?请你计算出所有可能方案的个数(包含题目给出的)。

为什么最后输出结果会是0?当被调函数中的if语句不成立时不想要它返回该如何?

  • 写回答

3条回答 默认 最新

  • ysuwood 2015-12-19 12:29
    关注

    不需要具体方案的程序见下面代码。
    如需要打印具体方案,参见我的博客(可能还在待审状态,csdn发个博客真费劲):

     #include <string.h>
    #include <stdio.h>
    #include <stdlib.h>
    
    int fun(int store,int flower,int wine)
    {
        if(store>5 || flower>10)
            return 0;
        else if(store==5 && flower==9 && wine==1)
        {
            return 1;
        }
        int re=0;
        re+=fun(store+1,flower,wine*2);
        re+=fun(store,flower+1,wine-1);
        return re;
    }
    
    void main()
    {
        printf("一共%d个方案\n\n",fun(0,0,2));
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么