爱奇艺 Java 第二题 dp 答案

package com.jinyukk;

import java.util.*;

/**
 * @author jinyukk
 * @date 2019/8/26 20:56
 * @description
 */
public class Test {
    static Double[][] dp;
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();   // red
        int m = in.nextInt();   // blue
        dp = new Double[n+1][m+1];
        double res = helper(n,m);
        System.out.println(String.format("%.5f",res));
    }

    private static double helper(int n, int m){
        if (n<=0 || m<0){
            return 0;
        }else if (n+m <= 2){
            if (m == 0) // n=1 m=0 || n=2 m=0
                return 1;
            else
                return 0.5; // n=1 m=1
        }else if (dp[n][m] != null)
            return dp[n][m];
        else{
            double ans = 1.0*n/(m+n);   // A 直接选择 red
            double t = 1.0*m/(m+n)*(m-1)/(m+n-1);   // A、B 选择 blue
            ans += helper(n-1,m-2)*t*n/(m+n-2) + helper(n,m-3)*t*(m-2)/(m+n-2); // C 选择 red || C 选择 blue
            dp[n][m] = ans;
            return ans;
        }
    }


}


#笔试题目##Java##爱奇艺##题解#
全部评论
过了吗?
点赞 回复 分享
发布于 2019-09-08 17:25
厉害
点赞 回复 分享
发布于 2019-09-08 17:34
厉害厉害
点赞 回复 分享
发布于 2019-09-08 17:35
double数组初始值不是0 吗
点赞 回复 分享
发布于 2019-09-08 18:34
所以这个dp只是用来记忆中间状态吗,本质还是递归加记忆?概率看晕了,没想好递归怎么往下一步
点赞 回复 分享
发布于 2019-09-08 20:08

相关推荐

点赞 评论 收藏
分享
评论
7
23
分享
牛客网
牛客企业服务