博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
poj2738 Two Ends
阅读量:5246 次
发布时间:2019-06-14

本文共 1090 字,大约阅读时间需要 3 分钟。

题目大意:两个人玩游戏,一些牌排成一行,当前玩家可以从最左端或者最右端拿一张牌,第一个人永远选择最优的方案,第二个人总是贪心的拿当前牌堆左右两端更大的,求最后第一个人拿的数字之和比第二个人大多少。

解题思路:题意和当时科创月赛的题很像,月赛时两个人都是选择最优方案。当时不懂dp(现在也只是初学),现在看来记忆化处理即可。对于每次拿牌,第一个人总是选择最优方案,因此可以搜索一下,即左右都拿,递归,记录下来;对于第二个人,只要枚举两种情况:左边更大or右边更大即可。这样就是一个记忆化搜索的过程。

#include 
#include
#include
#include
#include
using namespace std;const int N = 1010;int num[N];long long dp[N][N];long long compute(int l,int r){ if(dp[l][r]!=0){ //cout<
<<" "<
<
=num[r]){ ansl+=compute(l+2,r)-num[l+1]; } else{ ansl+=compute(l+1,r-1)-num[r]; } if(num[l]>=num[r-1]){ ansr+=compute(l+1,r-1)-num[l]; } else{ ansr+=compute(l,r-2)-num[r-1]; } dp[l][r]=max(ansl,ansr); } return dp[l][r];}int main(){ int n; int cnt=1; while(~scanf("%d",&n) && n!=0){ memset(dp,0,sizeof(dp)); for(int i=1;i<=n;i++){ scanf("%d",&num[i]); } long long ans=compute(1,n); printf("In game %d, the greedy strategy might lose by as many as %lld points.\n",cnt++,ans); } return 0;}

转载于:https://www.cnblogs.com/Scale-the-heights/p/4322339.html

你可能感兴趣的文章
Javascript format方法
查看>>
Javascript 绝对定位和相对定位
查看>>
ListView 应用5 - 数据库的增删改查及分页
查看>>
内置函数和匿名函数专区
查看>>
匿名内部类
查看>>
AJAX 表单提交 文件上传
查看>>
Redis拾遗(四)
查看>>
IOS多线程编程之锁的理解
查看>>
隐藏Apache版本号
查看>>
FPGA硬件加速
查看>>
Win7电脑开启局域网连接和共享过程中出现的"您可能没有权限使用网络资源"的解决办法...
查看>>
51. N-Queens
查看>>
vue父组件向子组件传递数据
查看>>
paip.hibernate list 返回位null的解决
查看>>
atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99
查看>>
Atitit.执行cli cmd的原理与调试
查看>>
浅谈JavaScript的Object类型
查看>>
JavaScript中的execCommand
查看>>
[LeetCode]7. Reverse Integer
查看>>
PHP设计模式(一)
查看>>