hdu 4293 dp求最大权值不重合区间
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4293
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; const int maxn = ; int G[maxn][maxn];
int dp[maxn]; //dp[i]表示前i个人,最大有多少个人没撒谎。 int main()
{
//freopen("E:\\acm\\input.txt","r",stdin);
int N;
while(cin>>N){
memset(G,,sizeof(G));
for(int i=;i<=N;i++){
int a,b;
scanf("%d %d",&a,&b);
if(a+b>=N) continue;
if(a+b<N && G[a][N-b]+a+b<N)
G[a][N-b]++; //G[a][N-b]表示区间(a,N-b]里面元素的个数。
}
memset(dp,,sizeof(dp));
int ans = ;
for(int i=;i<=N;i++){
dp[i] = max(dp[i],dp[i-]);
for(int j=i+;j<=N;j++){
if(G[i][j]){
dp[j] = max(dp[j],dp[i]+G[i][j]);
}
}
}
printf("%d\n",dp[N]);
}
}
//一直错误的原因就是把G[i][j]+i+N-j>N 的全部抹掉了。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; const int maxn = ; struct Node{
int A,B;
int num;
bool operator < (const Node& rhs) const{
return B > rhs.B;
}
}group[maxn]; int G[maxn][maxn];
int dp[maxn]; //dp[i]表示前i个人,最大有多少个人没撒谎。 int main()
{
//freopen("E:\\acm\\input.txt","r",stdin);
int N;
while(cin>>N){
memset(G,,sizeof(G));
for(int i=;i<=N;i++){
int a,b;
scanf("%d %d",&a,&b);
if(a+b<N && G[a][b]+a+b<N) //这句才是关键。WA的原因。
G[a][b]++;
}
int cnt = ;
for(int i=;i<N;i++)
for(int j=;j<N;j++){
if(G[i][j]){
group[cnt].A = i;
group[cnt].B = j;
group[cnt++].num = G[i][j];
}
}
sort(group,group+cnt);
memset(dp,,sizeof(dp));
int pv = ;
int i;
for(i=;i<=N;i++){
if(pv >= cnt) break;
int a = group[pv].A;
int num = group[pv].num;
int b = group[pv].B;
if(N-b == i){
dp[i] = max(dp[i-],dp[a]+num);
pv++;
while(pv < cnt && N-group[pv].B == i){
dp[i] = max(dp[i],dp[group[pv].A]+group[pv].num);
pv++;
}
}
else{
dp[i] = dp[i-];
}
}
printf("%d\n",dp[i-]);
}
}
hdu 4293 dp求最大权值不重合区间的更多相关文章
- hdu 1853 Cyclic Tour 最大权值匹配 全部点连成环的最小边权和
链接:http://acm.hdu.edu.cn/showproblem.php?pid=1853 Cyclic Tour Time Limit: 1000/1000 MS (Java/Others) ...
- hdu 1506(dp求最大子矩阵)
题意:容易理解... 分析:对于每个单位矩阵,我们先求出连续比它高的最左边的下标假设为l,然后求出比它高的最右边的下标假设为r,然后矩阵的面积就是(r-l+1)*1:我们从左到 右扫一遍,求出每个点的 ...
- hdu 2870(dp求最大子矩阵)
题意:让你求的是由同一字母组成的最大子矩阵,w可以变成a或者b,x可以变成b或者c,y可以变成a或者c,z可以变成a或者b或者c. 分析:这是hdu 1506.hdu 1505的加强版,具体的分析看我 ...
- hdu 1505(dp求最大子矩阵)
题意:就是让你求出全由F组成的最大子矩阵. 分析:这是hdu 1506的加强版,只不过这道题变成了2维的,那我们就一行一行的来.具体的分析见1506的博客:http://www.cnblogs.com ...
- Poj1163 The Triangle(动态规划求最大权值的路径)
一.Description 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 (Figure 1) Figure 1 shows a number triangle. Write a pro ...
- 紫书 例题 11-5 UVa 10048 (Floyd求最大权值最小的路径)
这道题是Floyd的变形 改成d[i][j] = min(d[i][j], max(d[i][k], d[k][j]))就好了. #include<cstdio> #include< ...
- 奔小康赚大钱 HDU - 2255(最大权值匹配 KM板题)
奔小康赚大钱 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU 4616 Game(经典树形dp+最大权值和链)
http://acm.hdu.edu.cn/showproblem.php?pid=4616 题意:给出一棵树,每个顶点有权值,还有存在陷阱,现在从任意一个顶点出发,并且每个顶点只能经过一次,如果经过 ...
- HDU 4514 - 湫湫系列故事——设计风景线 - [并查集判无向图环][树形DP求树的直径]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4514 Time Limit: 6000/3000 MS (Java/Others) Memory Li ...
随机推荐
- 使用Gulp构建本地开发Web服务器
前端模拟ajax,就需要配置web服务器(apache,iis,nginx),有点麻烦 代码有一点点修改,就需要F5刷新页面很麻烦 Gulp + Gulp-connect + watch + live ...
- JDBC连接池以及动态SQL处理
复习一下: 1.先创建一个properties配置文件 ClasssName=oracle.jdbc.driver.OracleDriver url=jdbc:oracle:thin:@服务器IP:端 ...
- Linux系统查找文件find命令使用(不断更新)
个人博客地址:http://www.cnblogs.com/wdfwolf3/. 使用格式:find [查找目录] [查找规则] [查找完后执行的操作] [查找目录] 即要查找的路径,可以使用 ...
- Java:对象的序列化
一.对象序列化机制 序列化机制允许将实现序列化的Java对象转换为字节序列,这些字节序列可以被保存在磁盘上或通过网络传输,以备以后重新恢复原来的对象: 序列化机制使得对象可以脱离程序的运行而独立存在: ...
- 把AS代码链接到fla文件
在属性里找到类,输入AS脚本的文件名然后点击右边的编辑就可以打开编辑AS脚本的界面,下面为链接代码. package { import flash.display.MovieClip; public ...
- PHP 面向对对象基础(接口,类)
介绍PHP面向对象的基础知识 1. 接口的定义interface ,类定义class,类支持abstract和final修饰符,abstract修饰为抽象类,抽象类 不支持直接实例化,final修饰的 ...
- 使用php发送电子邮件(phpmailer)
在项目开发过程中,经常会用到通过程序发送电子邮件,例如:注册用户通过邮件激活,通过邮件找回密码,发送报表等.这里介绍几种通过PHP发送电子邮件的 方式(1)通过mail()函数发送邮件(2)使用fso ...
- Python疑问系列
最近在看python源码 ------点点滴滴做个记录. 预计要分的系列: 1. import 分析 2. 主要bytecode 分析 3. python启动分析 4. object对象分析 最后希望 ...
- 2016多校联合训练contest4 1012Bubble Sort
Bubble Sort Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Tota ...
- Xsd: Xml序列化、反序列化的利器
下面讲述根据xml生成对应序列化反序列化类的过程,xml需要首先转化为xsd,然后再生成为实体类.其中,XSD是XML Schema Definition的缩写. 1.制作xml文件: <? ...