POJ3034+DP
题意:给定一个N*N的矩阵, 然后在这个矩阵的每个格子在任意时间会出现一个鼹鼠,这个出现
出现鼹鼠的时间是输出信息所确定的. 现在你手里有一把锤子能够去锤这些鼹鼠. 你能
够移动锤子,移动的两点之间的距离不能超过d,且中心在这条路径上的鼹鼠到都要受到
打击. 每个鼹鼠出现的时间值维持一秒钟. 现在问在一次游戏中最多打到多少鼹鼠
/*
dp
题意:给定一个N*N的矩阵, 然后在这个矩阵的每个格子在任意时间会出现一个鼹鼠,这个出现
出现鼹鼠的时间是输出信息所确定的. 现在你手里有一把锤子能够去锤这些鼹鼠. 你能
够移动锤子,移动的两点之间的距离不能超过d,且中心在这条路径上的鼹鼠到都要受到
打击. 每个鼹鼠出现的时间值维持一秒钟. 现在问在一次游戏中最多打到多少鼹鼠
思路:一开始状态定义正确,但是思路有问题,不能处理 k-1时刻 到 k时刻 的鼹鼠(也就是没法判断这“两种”鼹鼠的距离是否小于<=d) */
#include<algorithm>
#include<iostream>
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
#include<math.h>
#include<queue>
#include<stack>
#include<map>
#include<set>
using namespace std;
typedef long long int64;
//typedef __int64 int64;
typedef pair<int64,int64> PII;
#define MP(a,b) make_pair((a),(b))
const int inf = 0x3f3f3f3f;
const double pi=acos(-1.0);
const int dx[]={,-,,};
const int dy[]={,,,-};
const double eps = 1e-;
const int maxm = ;
const int maxn = ; int mat[ ][ maxn ][ maxn ];
int dp[ ][ maxn ][ maxn ];
//dp[t][x][y]:当t时刻,锤子打了xy的鼹鼠的MaxVal
int d; int dis2( int x1,int y1,int x2,int y2 ){
return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
} int Count( int cur_ti,int x1,int y1,int x2,int y2 ){
int cnt = ;
if( x1==x2 ){
if( y1>y2 ) swap( y1,y2 );
for( int i=y1;i<=y2;i++ ){
cnt += mat[ cur_ti ][ x1 ][ i ];
}
return cnt;
}
if( y1==y2 ){
if( x1>x2 ) swap( x1,x2 );
for( int i=x1;i<=x2;i++ ){
cnt += mat[ cur_ti ][ i ][ y1 ];
}
return cnt;
}
if( x1>x2 ){
swap( x1,x2 );
swap( y1,y2 );
}
for( int i=x1;i<=x2;i++ ){
if( ((i-x1)*y2+(x2-i)*y1)%(x2-x1)== ){
cnt += mat[ cur_ti ][ i ][ ((i-x1)*y2+(x2-i)*y1)/(x2-x1) ];
}
}
return cnt;
} int DP( int n,int MaxTi ){
n+=;
int ans = ;
for( int i=;i<=MaxTi+;i++ ){
for( int x=;x<n;x++ ){
for( int y=;y<n;y++ ){
dp[ i ][ x ][ y ] = ;
int Ymax = min( y+d,n- );
int Ymin = max( ,y-d );
int Xmax = min( x+d,n- );
int Xmin = max( ,x-d );
for( int x2=Xmin;x2<=Xmax;x2++ ){
for( int y2=Ymin;y2<=Ymax;y2++ ){
if( dis2( x,y,x2,y2 )<=d*d ){
dp[i][x][y] = max( dp[i][x][y],dp[i-][x2][y2]+Count( i-,x,y,x2,y2 ) );
}
}
}
ans = max( ans,dp[ i ][ x ][ y ] );
}
}
}
return ans;
} int main(){
int n,m;
while( scanf("%d%d%d",&n,&d,&m)== ){
if( n==&&d==&&m== )
break;
memset( mat,,sizeof( mat ) );
int MaxTi = ;
for( int i=;i<m;i++ ){
int x,y,t;
scanf("%d%d%d",&x,&y,&t);
x += ;
y += ;
MaxTi = max( MaxTi,t );
mat[ t ][ x ][ y ] = ;
}
int ans = DP( n,MaxTi );
printf("%d\n",ans);
}
return ;
}
下面把自己wa的也贴出来。。。
/* */
#include<algorithm>
#include<iostream>
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
#include<math.h>
#include<queue>
#include<stack>
#include<map>
#include<set>
using namespace std;
typedef long long int64;
//typedef __int64 int64;
typedef pair<int64,int64> PII;
#define MP(a,b) make_pair((a),(b))
const int inf = 0x3f3f3f3f;
const double pi=acos(-1.0);
const int dx[]={,-,,};
const int dy[]={,,,-};
const double eps = 1e-;
const int maxm = ;
const int maxn = ; struct Node{
double x,y;
int t;
}node[ maxn ];
double d; double dis( int i,int j ){
return sqrt( (node[i].x-node[j].x)*(node[i].x-node[j].x)+(node[i].y-node[j].y)*(node[i].y-node[j].y) );
} struct Node2{
int val;
int pre_mole;
int cur_mole;
}dp[ ][ maxn ];
//dp[i][j]:时刻i打了第j只地鼠
int cmp( Node a,Node b ){
if( a.t!=b.t ) return a.t<b.t;
else if( a.x!=b.x ) return a.x<b.x;
else if( a.y<b.y ) return a.y<b.y;
} bool OnLine3( int x,int y,int z ){
double sum = (node[x].x-node[y].x)*(node[y].y-node[z].y)-(node[y].x-node[z].x)*(node[x].y-node[y].y);
if( sum== ) return true;
return false;
} bool JudgeDis( int x,int y,int z ){
double d1 = dis( x,y );
double d2 = dis( x,z );
double d3 = dis( y,z );
if( d1>d||d2>d||d3>d ) return false;
return true;
} int main(){
int n,m;
//double d;
freopen("in.txt","r",stdin);
while( scanf("%d%lf%d",&n,&d,&m)== ){
if( n==&&d==&&m== )
break;
int M = -;
for( int i=;i<=m;i++ ){
scanf("%lf%lf%d",&node[i].x,&node[i].y,&node[i].t);
M = max( M,node[i].t );
}
sort( node+,node++m,cmp );
//for( int i=1;i<=m;i++ )
// printf("%lf %lf\n",node[i].x,node[i].y);
for( int i=;i<;i++ ){
for( int j=;j<maxn;j++ ){
dp[i][j].pre_mole = -;
dp[i][j].cur_mole = -;
dp[i][j].val = ;
}
}//init
for( int i=;i<=m;i++ ){
dp[ node[i].t ][ i ].val = ;
dp[ node[i].t ][ i ].cur_mole = i;
}
for( int i=;i<=m;i++ ){
//printf("\nNow = %d\n",i);
for( int j=i+;j<=m;j++ ){
//if( i==j ) continue;
//printf("j = %d\n",j);
if( node[j].t>node[i].t && dis( i,j )<=d ){
if( dp[ node[j].t ][ j ].val<dp[ node[i].t ][ i ].val+ ) {
dp[ node[j].t ][ j ].val = dp[ node[i].t ][ i ].val+;
dp[ node[j].t ][ j ].cur_mole = j;
dp[ node[j].t ][ j ].pre_mole = i;
}
}
else if( node[j].t==node[i].t ){
if( dp[ node[i].t ][ i ].pre_mole==- ){
if( dis(i,j)<=d && dp[ node[i].t ][ i ].val+>dp[ node[j].t ][ j ].val ){
dp[ node[j].t ][ j ].val = dp[ node[i].t ][ i ].val+;
dp[ node[j].t ][ j ].cur_mole = j;
dp[ node[j].t ][ j ].pre_mole = i;
}
}//
else {
if( OnLine3( dp[ node[i].t ][ i ].pre_mole,i,j )==true ){
if( JudgeDis( dp[ node[i].t ][ i ].pre_mole,i,j )==true && dp[ node[i].t ][ i ].val+>dp[ node[j].t ][ j ].val ){
dp[ node[j].t ][ j ].val = dp[ node[i].t ][ i ].val+;
dp[ node[j].t ][ j ].cur_mole = j;
dp[ node[j].t ][ j ].pre_mole = dp[ node[i].t ][ i ].pre_mole;
}
}
else if( node[j].t>node[dp[ node[i].t ][ i ].pre_mole].t ){
if( dis( i,j )<=d &&dp[ node[i].t ][ i ].val+>dp[ node[j].t ][ j ].val ){
dp[ node[j].t ][ j ].val = dp[ node[i].t ][ i ].val+;
dp[ node[j].t ][ j ].cur_mole = j;
dp[ node[j].t ][ j ].pre_mole = dp[ node[i].t ][ i ].pre_mole;
}
}
}
}
}
//for( int k=1;k<=m;k++ ){
//printf("num=%d, pre=%d, cur=%d\n",dp[node[k].t][k].val,dp[node[k].t][k].pre_mole,dp[node[k].t][k].cur_mole);
//}
}
int ans = ;
for( int i=;i<=M;i++ ){
for( int j=;j<=m;j++ ){
ans = max( ans,dp[i][j].val );
}
}
printf("%d\n",ans);
}
return ;
}
POJ3034+DP的更多相关文章
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
- android px转换为dip/dp
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...
随机推荐
- echarts标准饼图(二)——标题(title)配置
标题(title)配置 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- ATL一:CWindowImpl
1,#ifdef _ATL_DISABLE_NO_VTABLE#define ATL_NO_VTABLE#else#define ATL_NO_VTABLE __declspec(novtable)# ...
- How to: Create Your Own Test Certificate (.pfx)
Original MSDN Link: https://msdn.microsoft.com/en-us/library/ff699202.aspx
- 随机森林之Bagging法
摘要:在随机森林介绍中提到了Bagging方法,这里就具体的学习下bagging方法. Bagging方法是一个统计重采样的技术,它的基础是Bootstrap.基本思想是:利用Bootstrap方法重 ...
- IP HELPER GetAdaptersAddresses 函数
自己做的一些笔记,XP以及以后的系统使用: MSDN 函数:http://msdn.microsoft.com/en-US/library/windows/desktop/aa365915(v=vs. ...
- Delphi中的四舍五入函数
一.Delphi中的四舍五入法 四舍五入是一种应用非常广泛的近似计算方法,针对不同的应用需求,其有算术舍入法和银行家舍入法两种. 所谓算术舍入法,就是我们通常意义上的四舍五入法.其规则 ...
- 在SAE上同步djanogo的mysql数据库
折腾了一个下午,终于搞掂了把djanogo应用的mysql数据库导入到SAE上了,归根到底麻烦的根源是SAE限制多多.下面简单记录一下过程以备日后参考使用. 首先还是修改settings.py,把数据 ...
- ajax的post用法
<button>点击之后,显示ajax返回的数据</button> 首先在页面上新建了一个按钮,点击这个按钮后,执行ajax操作,并将返回的字符串显示在按钮上. 下面是ajax ...
- PHP视频教程 > PHP面向对象编程视频教程
当前位置: 主页 > 编程开发 > PHP视频教程 > PHP面向对象编程视频教程 > kingstone金士顿手机内存卡16G仅65元 1.1.什么是面向对象和类 上传日期: ...
- 深度:ARC会导致的内存泄露
iOS提供了ARC功能,很大程度上简化了内存管理的代码. 但使用ARC并不代表了不会发生内存泄露,使用不当照样会发生内存泄露. 下面列举两种内存泄露的情况. 1,循环参照 A有个属性参照B,B有个属性 ...