Python_enjoy 2024-01-26 16:47 采纳率: 76.9%
浏览 3
已结题

怎么优化啊+-*/C++

这怎么优化啊

#include <bits/stdc++.h>
using namespace std;
long long x,y,z;
long long f(long long i)
{
    if(i<=x+2)
        return 1;
    return f(i-1)+f(i-x-2)*y;
}
int main() {
    cin>>x>>y>>z;
    cout<<f(1+z);
    return 0;
}

  • 写回答

2条回答 默认 最新

  • 哎呀呀不会啊 2024-01-26 17:09
    关注
    #include <bits/stdc++.h>  
    using namespace std;  
      
    long long x,y,z;  
    map<long long, long long> memo;   
      
    long long f(long long i)  
    {  
        if(memo.count(i)) return memo[i]; / 
        if(i<=x+2)  
            return 1;  
        long long result = f(i-1) + f(i-x-2)*y;  
        memo[i] = result;   
        return result;  
    }  
      
    int main() {  
        cin>>x>>y>>z;  
        cout<<f(1+z);  
        return 0;  
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 1月27日
  • 已采纳回答 1月27日
  • 创建了问题 1月26日