poj3034--Whac-a-Mole(dp)
题目链接: id=3034">点击打开链接
题目大意:砸地鼠游戏,n*n的方格,锤子每次最多移动d,地鼠在t时刻出如今(x,y)时间。维持一个单位时间,不会在同一时间同一位置出现两仅仅老鼠,锤子能够砸经过的地鼠,问最多能够砸多少地鼠。(初始锤子能够在任何位置)
dp[t][i][j]:t时刻在锤子在(i,j)位置时能砸到的最多的地鼠个数
状态转移方程:由于锤子最多移动d,所以枚举(x-d,y-d)到(x+d,y+d)的点(tx,ty),觉得这是(x,y)向(tx,ty)移动的第一个点。然后计算在d范围内的点。统计被砸的地鼠的个数
注意:肯能通过边界外的点进行移动
20 5 4
1 0 1
0 1 1
0 5 2
1 6 2
0 0 0
结果是4
所以要将全部的点移动(5,5)的距离,能够避免负坐标
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std ;
int dp[12][41][41] ;
int Map[12][41][41] ;
void f(int n,int t,int x,int y,int d) {
int i , j , k , p , q , num ;
for(i = max(0,x-d) ; i <= min(n-1,x+d) ; i++) {
for(j = max(0,y-d) ; j <= min(n-1,y+d) ; j++) {
if( i == x && j == y ) continue ;
p = i - x ;
q = j - y ;
k = num = 0 ;
while( x+k*p >= 0 && x+k*p < n && y+k*q >= 0 && y+k*q < n && k*k*(q*q+p*p) <= d*d ) {
if( Map[t][x+k*p][y+k*q] ) num++ ;
dp[t][x][y] = max(dp[t][x][y],dp[t-1][x+k*p][y+k*q]+num) ;
k++ ;
}
}
}
return ;
}
int main() {
int n , d , m ;
int x , y , t ;
int i , j , max_t , ans ;
while( scanf("%d %d %d", &n, &d, &m) && n+d+m != 0 ) {
memset(dp,0,sizeof(dp)) ;
memset(Map,0,sizeof(Map)) ;
max_t = ans = 0 ;
while( m-- ) {
scanf("%d %d %d", &x, &y, &t) ;
Map[t][x+5][y+5] = 1 ;
max_t = max(max_t,t) ;
}
n += 12 ;
for(t = 1 ; t <= max_t ; t++) {
for(i = 0 ; i < n ; i++) {
for(j = 0 ; j < n ; j++) {
f(n,t,i,j,d) ;
ans = max(ans,dp[t][i][j]) ;
}
}
}
printf("%d\n", ans) ;
}
return 0 ;
}
poj3034--Whac-a-Mole(dp)的更多相关文章
- LightOJ 1033 Generating Palindromes(dp)
LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...
- lightOJ 1047 Neighbor House (DP)
lightOJ 1047 Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...
- UVA11125 - Arrange Some Marbles(dp)
UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...
- 【POJ 3071】 Football(DP)
[POJ 3071] Football(DP) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4350 Accepted ...
- 初探动态规划(DP)
学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...
- Tour(dp)
Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...
- 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)
.navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...
- Leetcode之动态规划(DP)专题-详解983. 最低票价(Minimum Cost For Tickets)
Leetcode之动态规划(DP)专题-983. 最低票价(Minimum Cost For Tickets) 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的 ...
- 最长公共子序列长度(dp)
/// 求两个字符串的最大公共子序列长度,最长公共子序列则并不要求连续,但要求前后顺序(dp) #include <bits/stdc++.h> using namespace std; ...
- Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings)
Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings) 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子 ...
随机推荐
- [luoguP1963] [NOI2009]变换序列(二分图最大匹配)
传送门 根据公式xjb推一下,然后就可以连边. 考虑到字典序最小,和匈牙利算法的实现过程,要倒序匹配. #include <cmath> #include <cstdio> # ...
- 算法复习——状压dp
状压dp的核心在于,当我们不能通过表现单一的对象的状态来达到dp的最优子结构和无后效性原则时,我们可能保存多个元素的有关信息··这时候利用2进制的01来表示每个元素相关状态并将其压缩成2进制数就可以达 ...
- java中文乱码问题解决
1 处理乱码方式: 1 连接数据库的时候 jdbc.properties:jdbc:mysql://localhost:3306/myproject?useUnicode=true&chara ...
- 【CF500D】New Year Santa Network(树上统计)
..]of longint; z:..]of extended; n,i,m,tot,x1:longint; ans,fenmu,y1:extended; procedure add(a,b:long ...
- cpu乱序执行
http://blog.163.com/zhaojie_ding/blog/static/1729728952007925111324379/?suggestedreading 处理器的乱序和并发执行 ...
- 一个页面多个ng-app注意事项
1.一个页面会自动加载第一个ng-app 2.如果想启动其它ng-app,需要通过下列代码的红色部分来启动,此时一共启动了2个ng-app 3.特别注意:代码红色部分一定要放在最后,比如,不能放在蓝色 ...
- 推荐!手把手教你使用Git(转)
原文出处: 涂根华的博客 欢迎分享原创到伯乐头条 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放 ...
- Centos7源码安装MySQL5.7
a.连接数据库报111 从一台linux远程连接另一台linux上的MySQL,出现ERROR 2003 (HY000): Can't connect to MySQL server on 'xxx. ...
- spring与事务管理
就我接触到的事务,使用最多的事务管理器是JDBC事务管理器.现在就记录下在spring中是如何使用JDBC事务管理器 1)在spring中配置事务管理器 <!-- JDBC事务 --> ...
- 使用python一步一步搭建微信公众平台
https://my.oschina.net/yangyanxing/blog/159215 http://www.ziqiangxuetang.com/django/python-django-we ...