朴素动态规划

ZOJ3161



题意:(严重标题党)老板不想让客人走,客人不想留,客人按顺序排好,老板抽8g(书上翻译成八卦,神翻译),抽到的

如果相邻,其中一个人由客人决定离开,求最后黑心的老板最多能让多少人留下。



输入:

n(客人个数),m(8g关系对数)

a(客人a),b(客人b)(m行)



输出:

T(最多留下的人数)

思路:之前看题目的时候看懂了,但压根想不出来怎么用dp做,因为我考虑到既然老板要求最多人,而且走人的时候又由客人来选择谁走,那么情况应该很复杂(后来证明我想多了),书上的算法分析是这样说的,整个序列可以分成一些独立的部分,每一个部分相邻的两个人都有8g,并且互不影响(当时就一直在纠结这里),然后我想了下,如果可以分成很多序列的话,要做预处理,先解出F[i]这个状态i个人这样的序列有多少,用数组存放,然后dp,dp方程其实就是判定i个人状态下,

最多有多少个人能留下来,如果我们假设枚举的是第j个人,那么相邻的就是j和j+1,所以如果走的是j,j-1和i-j代表的就是除去j后的状态,而j和i-(j+1)就是除去j+1后的状态,选取较小的和状态i比较,然后最大的就是最优的结果。最后因为dp保存的是单个序列下能留下的最大人数,所以前面预处理的数组要用上。

#include<iostream>
#include <stdio.h>
#include <cstring>
#include <cmath>
using namespace std;
#define MAX 505
int F[MAX];
int flag[MAX];
int n,m;
int main()
{ int index_t[MAX][MAX];
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(flag,0,sizeof(flag));
memset(index_t,0,sizeof(index_t));
memset(F,0,sizeof(F));
for(int i=1; i<=m; i++)
{
int a,b;
scanf("%d%d",&a,&b);
if(abs(a-b)==1)
{
index_t[a+1][b+1]=1;
index_t[b+1][a+1]=1;//预处理
}
}
for(int i=1; i<=n; i++)
{
int count=1;
while(index_t[i][i+1])
{
count++;
i++;
}
flag[count]++;
}
F[0]=0;
F[1]=1;
F[2]=1;
F[3]=1; for(int i=4; i<=n; i++)
for(int j=1; j<i; j++)
F[i]=max(F[i],min(F[j]+F[i-j-1],F[j-1]+F[i-j])); int ans=flag[1];
for(int i=2; i<=n; i++)
ans+=flag[i]*F[i];
printf("%d\n",ans);
}
return 0;
}

ZOJ3161的更多相关文章

  1. zoj3161 Damn Couples

    不想打题面了,题面戳这里 这道题目的模型转换地有点猛.首先我们肯定需要让老板把那些不相邻的人的卡牌放在前面,这样他们就作废了.然后剩下的卡牌就都是相邻人之间的了.我们就可以把这个序列分成若干个联通块, ...

随机推荐

  1. gearmand的安装

    1.安装gperf libuuid-devel yum install -y gperf libuuid-devel 2.安装 libevent yum install libevent libeve ...

  2. Java学习----运算符与表达式

    一.运算符 1.算术运算符 +   -   *   /  %  ++  -- public class Test7 { public static void main(String[] args) { ...

  3. JS 操作Dom节点之样式

    为了提高用户体验,我们经常会动态修改Dom节点的样式,各种浏览器差异比较大,我们如何应对?不断尝试,不断总结~! 1. style.getComputedStyle.currentStyle 内嵌样式 ...

  4. sql server 调优----索引缺失

    SELECT mig.index_group_handle, mid.index_handle, CONVERT (decimal (28,1), migs.avg_total_user_cost * ...

  5. TCP客户/服务器程序概述

    一个回射服务器: 1)客户从标准输入读入一行文本,并写给服务器 2)服务器从网络输入读入这行文本,并回射给客户 3)客户从网络输入读入这行回射文本,并显示在标准输出上 回射输入行这样一个客户/服务器程 ...

  6. Hadoop 学习笔记(二) HDFS API

    4.删除HDFS上的文件 package proj; import java.io.IOException; import org.apache.hadoop.conf.Configuration; ...

  7. Java进阶代码

    本文重在温习……不过初学以及进阶高手不可错过 1.  public static void arraycopy(全小写)(object src,int srcPos,object dest,int d ...

  8. poj 1573Robot Motion

    http://poj.org/problem?id=1573 #include<cstdio> #include<cstring> #include<algorithm& ...

  9. Oracle 用户权限管理

    SQL> select * from ROLE_SYS_PRIVS where ROLE='RESOURCE'; ROLE PRIVILEGE ADM --------------------- ...

  10. COJ 1003 WZJ的数据结构(三)ST表

    WZJ的数据结构(三) 难度级别:B: 运行时间限制:3000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 请你设计一个数据结构,完成以下功能: 给定一个大小为N的 ...