其他分享
首页 > 其他分享> > 排成一条线的纸牌博弈问题

排成一条线的纸牌博弈问题

作者:互联网

链接
给定一个整型数组arr,代表数值不同的纸牌排成一条线,玩家A和玩家B依次拿走每张纸牌,规定玩家A先拿,玩家B后拿,但是每个玩家每次只能拿走最左和最右的纸牌,玩家A和玩家B绝顶聪明。请返回最后的获胜者的分数。

import java.util.Scanner;

public class Main {

    private static int first(int[] arr, int L, int R) {
        if (L == R) {
            return 0;
        }
        return Math.max(arr[L] + second(arr, L + 1, R), arr[R] + second(arr, L, R - 1));
    }

    private static int second(int[] arr, int L, int R) {
        if (L == R) {
            return 0;
        }
        return Math.min(first(arr, L + 1, R), first(arr, L, R - 1));
    }

    private static int solve(int[] arr) {
        int n = arr.length;
        int[][] first = new int[n][n];
        int[][] second = new int[n][n];
        for (int i = 0; i < n; ++i) {
            first[i][i] = arr[i];
        }

        for (int L = n - 2; L >= 0; --L) {
            for (int R = L + 1; R < n; ++R) {
                first[L][R] = Math.max(arr[L] + second[L + 1][R], arr[R] + second[L][R - 1]);
                second[L][R] = Math.min(first[L + 1][R], first[L][R - 1]);
            }
        }

        return Math.max(first[0][n - 1], second[0][n - 1]);
    }

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            int n = in.nextInt();
            int[] arr = new int[n];
            for (int i = 0; i < n; ++i) {
                arr[i] = in.nextInt();
            }
            System.out.println(solve(arr));
        }
    }
}

标签:arr,排成,纸牌,int,玩家,second,一条线,Math,first
来源: https://www.cnblogs.com/tianyiya/p/15428409.html