Проблема с золотым ящиком (подход)
В ряд поставлено n золотых коробок, в каждой из которых разное количество золотых монет. 2 игрока играют в игру, цель которой - собрать максимальное количество золотых монет. Каждый игрок может видеть, сколько монет находится в каждой коробке, но может получить коробку только с любого конца в свой ход. Разработайте стратегию так, чтобы победил Player1 (при условии, что оба игрока играют умно)
Эту проблему задали в интервью Amazon. Я пробовал такой подход:
#include<stdio.h>
int max(int a, int b) {
return a>b?a:b;
}
int maxCoins(int arr[], int i, int j, int turn) {
if(i==j) {
if(turn == 1) return arr[i];
else return 0;
}
if(turn) {
return max(arr[i] + maxCoins(arr,i+1,j,0),arr[j] + maxCoins(arr,i,j-1,0));
} else {
if(arr[i]>arr[j])
return maxCoins(arr,i+1,j,1);
else
return maxCoins(arr,i,j-1,1);
}
}
int main() {
int arr[10] = {6,7,4,1,10,5,4,9,20,8}; //{2,3,4,5,6,7,8,9,10,11};
printf("%d\n",maxCoins(arr,0,9,1));
}
Но я считаю, что это неправильно, так как player2 тоже шустро играет. Пожалуйста, помогите с тем, что мне не хватает.