qq_73895884 2022-10-18 22:18 采纳率: 76.9%
浏览 18
已结题

如何用偏基础的c语言递归和动态规划解决该问题

如何用偏基础的C语言递归程序和动态规划程序分别解决这个问题,希望给出两种方法
数据范围在一千左右

img

  • 写回答

2条回答 默认 最新

  • 关注

    代码如下:
    (1)递归

    #include <stdio.h>
    
    long long Cnk(int n,int k)
    {
        if(k==0 ||k==n)
            return 1;
        else
            return Cnk(n-1,k)+Cnk(n-1,k-1);
    }
    
    
    int main()
    {
        int n,k;
        long long res = 0;
        scanf("%d %d",&n,&k);
        res = Cnk(n,k);
        printf("%lld",res);
        return 0;
    }
    

    (2)

    #include <stdio.h>
    long long Jiecheng(int n)
    {
        long long s = 1;
        for(int i=1;i<=n;i++)
            s *= i;
        return s;
    }
    
    
    long long Cnk(int n,int k)
    {
        return Jiecheng(n)/Jiecheng(k)/Jiecheng(n-k);
    }
    
    
    int main()
    {
        int n,k;
        long long res = 0;
        scanf("%d %d",&n,&k);
        res = Cnk(n,k);
        printf("%lld",res);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月26日
  • 已采纳回答 10月18日
  • 创建了问题 10月18日