题解 | C++10行最优解

丢棋子问题

http://www.nowcoder.com/practice/d1418aaa147a4cb394c3c3efc4302266

要理解的话把图画出来,写出递推方程。

public:
    int solve(int n, int k) {
        if(n <= 1 || k == 1) return n;;
        int a = log2(n) + 1, ret = 0;
        if(k >= n) return a;
        vector<int> dp(k);
        while(true) {
            ++ret;
            for(int i = k - 1; i >= 0; --i) {
                dp[i] = dp[i] + dp[i - 1] + 1;
                if(dp[i] >= n)
                    return ret;
            }
        }
    }
};
全部评论

相关推荐

12-19 22:04
武汉大学 Java
点赞 评论 收藏
分享
12-15 11:27
门头沟学院 Java
哇哇的菜鸡oc:所有人不要理会,就好了,后面他就知道怎么回事了,只能说有的时候市场都是被宰的人搞坏的
点赞 评论 收藏
分享
牛马人的牛马人生:500一天吗?香麻了
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务