感觉早些年IOI的题都不难啊,也就NOIp难度……现在貌似变难了

状态用dp[n][a1][b1][a2][b2]表示

n表示处理到前n个餐车

第一组矿工得到的最近一种食物用a1表示,a1的上一种食物用b1表示,第二组矿工的用a2和b2表示

a和b的取值范围为[0,3],0表示没有食物,1~3分别表示三种食物中的一种

第一维可以用滚动数组优化空间

 #include <cstdio>
 #include <cstring>
 #include <algorithm>

 ;

 ][][][][];
 //none=0,bread=1,meat=2,fish=3
 int N;
 char seq[maxN];
 int s[maxN];

 inline int code(char x)
 {
     switch(x)
     {
     ;
     ;
     ;
     }
     ; //unused
 }

 void input()
 {
     scanf("%d",&N);
     scanf("%s",seq);
     ;i<N;i++) s[i]=code(seq[i]);
 }

 inline int val(int cur,int last1,int last2)
 {
     ) :;
     :;
     :;
 }

 int solve()
 {
     memset(dp[],]));
     dp[][s[]][][][]=dp[][][][s[]][]=;
     ;i<N;i++)
     {
         int& v=s[i];
         memset(dp[],]));
         ;a1<;a1++)
         {
             if(!a1) { //b1=0
                 ;a2<;a2++)
                     ;b2<;b2++) {
                         dp[][v][][a2][b2]=std::max
                                 (dp[][v][][a2][b2],
                                 dp[][][][a2][b2]+);
                         dp[][][][v][a2]=std::max
                                 (dp[][][][v][a2],
                                 dp[][][][a2][b2]+val(v,a2,b2));
                     }
             }
             ;b1<;b1++)
                 ;a2<;a2++)
                 {
                     if(!a2) {
                         dp[][a1][b1][v][]=std::max
                                 (dp[][a1][b1][v][],
                                 dp[][a1][b1][][]+);
                         dp[][v][a1][][]=std::max
                                 (dp[][v][a1][][],
                                 dp[][a1][b1][][]+val(v,a1,b1));
                     }
                     ;b2<;b2++) {
                         dp[][v][a1][a2][b2]=std::max
                                 (dp[][v][a1][a2][b2],
                                  dp[][a1][b1][a2][b2]+val(v,a1,b1));
                         dp[][a1][b1][v][a2]=std::max
                                 (dp[][a1][b1][v][a2],
                                  dp[][a1][b1][a2][b2]+val(v,a2,b2));
                     }
                 }
         }
         memcpy(dp[],dp[],]));
     }
     ;
     ;a1<;a1++)
         ;b1<;b1++)
             ;a2<;a2++)
                 ;b2<;b2++)
                     ans=std::max(ans,dp[][a1][b1][a2][b2]);
     return ans;
 }

 int main()
 {
     input();
     printf("%d\n",solve());
     ;
 }

Vijos1386 IOI2007 矿工配餐 动态规划的更多相关文章

  1. BZOJ 1806 IOI2007 Miners 矿工配餐 动态规划

    题目大意:将一个123序列拆分为两个子序列.定义每一个数的贡献值为以这个数结尾的长度最大为3的子串中不同数的数量,求贡献值和的最大值 令f[i][a1][a2][b1][b2]为前i个数分成两组,第一 ...

  2. [IOI2007]矿工配餐

    状态是f[i][a][b][c][d]表示第i个餐车,1号矿洞最近两顿是a,b,2号矿洞最近两顿是c,d. 给的空间是16MB,滚动数组滚动了第一维就行了 (给的变量是char是因为这个不超过256, ...

  3. [Ioi2007]Miners 矿工配餐(BZOJ1806)

    [Ioi2007]Miners 矿工配餐 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 214  Solved: 128 Description 现有两 ...

  4. BZOJ 1806: [Ioi2007]Miners 矿工配餐( dp )

    dp... ------------------------------------------------------------------------------- #include<cs ...

  5. bzoj1806 [Ioi2007]Miners矿工配餐

    [bzoj1806][Ioi2007]Miners 矿工配餐 2014年7月10日1,7870 Description 现有两个煤矿,每个煤矿都雇用一组矿工.采煤工作很辛苦,所以矿工们需要良好饮食.每 ...

  6. [bzoj1806] [ioi2007]Miners 矿工配餐

    相当于noip前两题难度的ioi题........ 还是挺好想的...算是状压一下?...两个二进制位可以表示三种食物或者没有,所以用四个二进制位表示某个煤矿最近两餐的情况... 先把各种情况加上各种 ...

  7. [IOI2007 D1T1]Miners 矿工配餐

    题目大意:有$2$个煤矿,$n$天.每天给一个煤矿送餐(共有有$3$种餐),价值为它与前面两次送餐(如果有的话)不同的种类数.最大化价值. 题解:看到只有三种餐,考虑状压$DP$.$f_{i,j,k, ...

  8. BZOJ 1806: [Ioi2007]Miners 矿工配餐

    ime Limit: 10 Sec  Memory Limit: 64 MBSubmit: 910  Solved: 559[Submit][Status][Discuss] Description ...

  9. bzoj 1806 [Ioi2007]Miners 矿工配餐(DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1806 [题意] 给定一个权在1..3内的序列,在保持相对位置不变的情况下拆分成两个序列 ...

随机推荐

  1. lambda -- Filter Java Stream to 1 and only 1 element

    up vote10down votefavorite I am trying to use Java 8 Streams to find elements in a LinkedList. I wan ...

  2. 常用myeclipse的快捷键,对菜鸟超有用的

    1. ctrl + h ,这个键超有用的,可以搜索当前项目的整个文件,并锁定到改文件的 具体位置.如图: 2.ctrl + o,在java文件内,搜索该文件下的所有方法.如图: ctrl + d ,删 ...

  3. LoadRunner的场景设置

    loadrunner场景设置的方法: 1.逐步增加用户数,分多次去运行场景.比如:第一次运行50并发,第二次运行100并发…… 2.针对同一个脚本设置多个组,使用组策略(点击Edit Schedule ...

  4. 【狼】unity 鼠标拖拽物体实现任意角度自旋转

    主要涉及函数 Input.GetAxis(“Mouse x”) 可取得鼠标横向(x轴)移动增量 Input.GetAxis(“Mouse y”) 可取得鼠标竖向(y轴)移动增量 通过勾股定理获取拖拽长 ...

  5. 关于将客户端移植到Lua的解决方案设想。

    现在发行商都需要cp们做热更新,而对于unity制作的游戏来讲,这个恐怕是个噩梦,而项目已经进行到中后期,确实很麻烦,有UniLua,但是如果全部手动解决恐怕上不了线了工作量太大,初步设想如果做一个基 ...

  6. HDOJ/HDU 1039 Easier Done Than Said?(字符串处理~)

    Problem Description Password security is a tricky thing. Users prefer simple passwords that are easy ...

  7. ACM3787

    /* 问题说明 给定两个整数A和B,其表示形式是:从个位开始, 每三位数用逗号","隔开. 现在请计算A+B的结果,并以正常形式输出. 输入 输入包含多组数据数据,每组数据占一行, ...

  8. 【动态规划】天堂(Heaven) 解题报告

    天堂(heaven) 题目描述 每一个要上天堂的人都要经历一番考验,当然包括小X,小X开始了他进入天堂的奇异之旅.地狱有18层,天堂竟然和地狱一样,也有很多很多层,天堂共有N层.从下到上依次是第1,2 ...

  9. HDU 3078 Network LCA

    题意:n个点 m个询问,下面一行是n 个点的权值 再下面n-1行是双向的边 然后m个询问:k u v 若k==0,则把u点的权值改为v,否则回答u->v之间最短路经过点的权值中  第k大的值是多 ...

  10. 转 jquery 学习笔记

    jQ通过选择器选择元素,选择器的语法和css类似$(css选择器语法) 参数可以是id.class.tag等等通过如上选择就可以获得一个元素 jQuery名字冲突 解决方法: var jq=jQuer ...