题意:给定一个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的更多相关文章

  1. BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]

    1911: [Apio2010]特别行动队 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 4142  Solved: 1964[Submit][Statu ...

  2. 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 ...

  3. AEAI DP V3.7.0 发布,开源综合应用开发平台

    1  升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...

  4. AEAI DP V3.6.0 升级说明,开源综合应用开发平台

    AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...

  5. BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]

    1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4026  Solved: 1473[Submit] ...

  6. [斜率优化DP]【学习笔记】【更新中】

    参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...

  7. BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9812  Solved: 3978[Submit][St ...

  8. px、dp和sp,这些单位有什么区别?

    DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...

  9. android px转换为dip/dp

    /** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...

随机推荐

  1. ios开发:GCD多线程

    ios有三种多线程编程技术,分别是NSThread,Cocoa NSOperation和GCD,GCD全称Grand Central Dispatch 是Apple开发的一个多核编程的解决方法,在iO ...

  2. JavaScript DOM编程艺术第一章:JavaScript简史

    本系列的博客是由本人在阅读<JavaScript DOM编程艺术>一书过程中做的总结.前面的偏理论部分都是书中原话,觉得有必要记录下来,方便自己翻阅,也希望能为读到本博客的人提供一些帮助, ...

  3. WinSCP列出’/’目录项出错

    无法获得目录列表 如图所示,使用百度云虚拟机时,FTP连接服务器,出现错提示,官方给出的说法是使用其他的FTP进行连接,但是之前成功连接过,查找资料后说是打开过png,mp3等媒体文件,切换路径时出错 ...

  4. 《APUE》第6章练习1

    问题:编写一个程序,它调用uname并输出utsname结构中的所有字段,并将输出与uname(1)命令的输出结构做比较. 我本来以为utsname结构也跟passwd结构一样,也有那三个函数来获取整 ...

  5. JQ批量控制form禁用

    <script type="text/javascript" src="http://www.joy-city.com.cn/templets/default/sc ...

  6. checkBox控件的CheckedChanged与CheckedStateChanged区别

    Checked属性为bool类型,CheckState属性为枚举类型(CheckState.Checked.CheckState.Unchecked和CheckState.Indeterminate) ...

  7. 【原】隐藏ultraGrid1指定列

    void uGrdAllFlight_InitializeRow(object sender, InitializeRowEventArgs e) { /***********TEST START** ...

  8. 利用WeX5集成百度地图

    最近做一个地图类的app经过几天的摸索,终于完成百度地图集成的界面先看效果:1.加载完成之后,页面加载制定位置的地图2.顶部能够输入地图的关键字,地图显示符合条件的下拉列表3.用户选择了相应的选项后, ...

  9. IE6/IE7中li底部4px的Bug

    当li的子元素中有浮动(float)时,IE6/IE7中<li>元素的下面会产生4px空隙的bug. XHTML <ul class="list"> < ...

  10. mongo数据库基础操作

    概念 一个mongod服务可以有建立多个数据库,每个数据库可以有多张表,这里的表名叫collection,每个collection可以存放多个文档(document),每个文档都以BSON(binar ...