通过这题发现了double的坑点,本来认为double表示范围可能跟long long差不了多少,在wa了n次之后发现double表示的长度是16位,而2的60次方已经到了18位的长度了,当然不对,所以这题不能图省劲直接用powhan's
题解:
这题就是让我们算这颗树最不平衡的时候根节点左右子数结点的差,所以我们让一颗树满结点,另一棵树是最少结点的个数即可算出,满结点的树可以一下算出结点个数,呢么怎么算那一颗不满结点的树呢?
我们可以从上往下推
公式dp[i]=dp[i-1]+dp[i-d-1]+1
dp[i]表示深度为i的子树最少总节点个数
意思就是在深度为i的结点是由左子树深度(i-1)和右子树(i-d-1)这两棵树组成的
代码:

/*Keep on going Never give up*/
#pragma GCC optimize(3,"Ofast","inline")
#include <bits/stdc++.h>
const int maxn = 110;
const int MaxN = 0x3f3f3f3f;
const int MinN = 0xc0c0c00c;
typedef long long ll;
const int mod = 100000000;
using namespace std;

ll dp[maxn];
int main(){
    int n,d;
    cin>>n>>d;
    ll ans=1;
    for(int i=0;i<n-1;i++) ans*=2;
    ans=ans-1;
    dp[1]=1;
    for(int i=2;i<=n;i++){
        if(i>d) dp[i]=dp[i-1]+dp[i-d-1]+1;
        else dp[i]=dp[i-1]+1;
    }
    cout<<dp[max(n-d-1,0)]<<endl;
    return 0;
}