51NOD1522 上下序列/CF567F Mausoleum DP
考虑状态$f_{p,q}$表示左边已经填了$p$个,右边填了$q$个的方案(其实可以压掉其中一维),考虑第$i$个数字的转移,有$3$种:
$a:$将这两个$i$都放在序列最左边;$b:$将这两个$i$放在序列最右边;$c.$将这两个$i$一个放一边。
对于$K$个约束条件我们可以在加入的时候直接判断:当前加入的两个数相等,没加入的位置的数必定比当前加的数大,而其他已经填好的地方一定比当前的数小。
最后的答案是$\frac{\sum\limits_{i=0}^{2n}f_{i,2n-i}}{3}$,除3是因为对于最后一次加入,$abc$三种方案都是可行的,但是我们只能算一种。
注意判断约束条件时的细节,约束条件的存储可以使用类似邻接表的方法,在加入约束条件时如加入无向边一样变成两个约束条件,判断起来会方便一些。
#include<bits/stdc++.h> #define int long long using namespace std; ][] , numOp[]; vector < ] , op[]; map < string , int > opToNum; bool ifOK(int l , int r , int que1 , int que2){ //特别注意判断que1位置与que2位置有联系的情况 ; i < numOp[que1] ; i++) switch(op[que1][i]){ : if(num[que1][i] < r && num[que1][i] > l || num[que1][i] == que2) ; break; : if(num[que1][i] < r && num[que1][i] > l && num[que1][i] != que2) ; break; : if(!(num[que1][i] == que2)) ; break; : if(!(num[que1][i] <= r && num[que1][i] >= l || num[que1][i] == que2)) ; break; : if(!(num[que1][i] < r && num[que1][i] > l) || num[que1][i] == que2) ; } ; i < numOp[que2] ; i++) switch(op[que2][i]){ : if(num[que2][i] < r && num[que2][i] > l || num[que2][i] == que1) ; break; : if(num[que2][i] < r && num[que2][i] > l && num[que2][i] != que1) ; break; : if(!(num[que2][i] == que1)) ; break; : if(!(num[que2][i] <= r && num[que2][i] >= l || num[que2][i] == que1)) ; break; : if(!(num[que2][i] < r && num[que2][i] > l) || num[que2][i] == que1) ; } ; } main(){ opToNum.insert(make_pair()); opToNum.insert(make_pair()); opToNum.insert(make_pair()); opToNum.insert(make_pair()); opToNum.insert(make_pair()); int N , K; for(cin >> N >> K ; K ; K--){ int a , b , t; string s; cin >> a >> s >> b; t = opToNum.find(s)->second; if(a == b) || t == ){ cout << ; ; } else continue; num[a].push_back(b); op[a].push_back(t); num[b].push_back(a); op[b].push_back( - t); numOp[a]++; numOp[b]++; } ans[][] = ; ; i <= N ; i++){ //DP * i ; j >= ; j--) ][ * i - j] && ifOK(j , * N - * i + j + , j , j - )) ans[j][ * i - j] += ans[j - ][ * i - j]; * i ; j >= ; j--) * i - j][j - ] && ifOK( * i - j , * N - j + , * N - j + , * N - j + )) ans[ * i - j][j] += ans[ * i - j][j - ]; ; j < * i ; j++) * i - j - ][j - ] && ifOK( * i - j , * N - j + , * i - j , * N - j + )) ans[ * i - j][j] += ans[ * i - j - ][j - ]; } ; ; i <= * N ; i++) all += ans[i][ * N - i]; cout << all / ; ; }
51NOD1522 上下序列/CF567F Mausoleum DP的更多相关文章
- 括号序列(区间dp)
括号序列(区间dp) 输入一个长度不超过100的,由"(",")","[",")"组成的序列,请添加尽量少的括号,得到一 ...
- 区间和序列上的dp
区间上的dp状态设计最基本的形式: \(F[i]\)表示以i结尾的最优值或方案数. \(F[i][k]\)表示以i结尾附加信息为k的最优值或方案数. 当然可以有多维附加信息. 转移的话往往是枚举上一个 ...
- bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp)
bzoj4032/luoguP4112 [HEOI2015]最短不公共子串(后缀自动机+序列自动机上dp) bzoj Luogu 题解时间 给两个小写字母串 $ A $ , $ B $ ,请你计算: ...
- LGTB与序列 状压dp
考试一看我就想到了状压dp.当时没有想到素数,以为每一位只有0~9这些数,就开始压了.后来发现是小于30,然后改到了15,发现数据一点不给面子,一个小点得数都没有,完美爆零.. 考虑到bi最多变成58 ...
- 「长乐集训 2017 Day10」划分序列 (二分 dp)
「长乐集训 2017 Day10」划分序列 题目描述 给定一个长度为 n nn 的序列 Ai A_iAi,现在要求把这个序列分成恰好 K KK 段,(每一段是一个连续子序列,且每个元素恰好属于一 ...
- 【Foreign】划分序列 [线段树][DP]
划分序列 Time Limit: 20 Sec Memory Limit: 256 MB Description Input Output 仅一行一个整数表示答案. Sample Input 9 4 ...
- 九度OJ 1077:最大序列和 (DP)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5600 解决:1637 题目描述: 给出一个整数序列S,其中有N个数,定义其中一个非空连续子序列T中所有数的和为T的"序列和&qu ...
- 算法复习——求最长不下降序列长度(dp算法)
题目: 题目背景 161114-练习-DAY1-AHSDFZ T2 题目描述 有 N 辆列车,标记为 1,2,3,…,N.它们按照一定的次序进站,站台共有 K 个轨道,轨道遵从先进先出的原则.列车进入 ...
- hdu 4521 小明系列问题——小明序列(线段树+DP或扩展成经典的LIS)
小明系列问题--小明序列 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Tot ...
随机推荐
- 从输入url到页面展示到底发生了什么
阅读目录 1.输入地址 2.浏览器查找域名的 IP 地址 3.浏览器向 web 服务器发送一个 HTTP 请求 4.服务器的永久重定向响应 5.浏览器跟踪重定向地址 6.服务器处理请求 7.服务器返回 ...
- Java并发编程(二)同步
在多线程的应用中,两个或者两个以上的线程需要共享对同一个数据的存取.如果两个线程存取相同的对象,并且每一个线程都调用了修改该对象的方法,这种情况通常成为竞争条件. 竞争条件最容易理解的例子就是:比如 ...
- springcloud 入门 8 (config配置中心)
Spring Cloud Config: 配置中心为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件,它就是Spring Cloud Config. 在分布式系统中,由于服务数量巨多, ...
- Python tab键命令补全
pip install pyreadline import rlcompleter, readline readline.parse_and_bind('tab: complete') root@pe ...
- 命令行选项 - Mozilla 产品与私有技术 | MDN - Google Chrome
命令行选项 在本文章中 语法规则 使用命令行选项 示例 用户配置档 -CreateProfile profile_name -CreateProfile "profile_name prof ...
- CSS网页菜单
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="WebUserContro ...
- Windows10 内存泄漏
之前遇到win10开机idle一段时间后, 内存噌噌的往上彪, 16G内存基本什么东西没开就90%多.查了网上的一些解决方案: 方法1. 关闭Ndu服务 sc config Ndu start=dis ...
- Windows批处理 -- 打造MySQLCleaner
批处理打造MySQLCleaner 1. 简介 在我们卸载MySQL数据库的时候,往往除了需要卸载软件,还需要删除各种注册表信息,隐藏文件,卸载服务,否则当我们再次安装MySQL时就会出现 ...
- Linux之特殊的环境变量IFS以及如何删除带有空格的目录
1.IFS是什么? Linux下有一个特殊的环境变量叫做IFS,叫做内部字段分隔符(internal field separator).IFS环境变量定义了bash shell用户字段分隔符的一系列字 ...
- Mysql基础之 binary关键字
where子句的字符串比较是不区分大小写的,但是可以使用binary关键字设定where子句区分大小写