Description

  

​   一排\(n\)个格子,每个格子可以涂三种颜色的一种。现在给出\(m\)个形如“\([l,r]\)中必须恰好有\(x\)种颜色"的限制(\(1 \le l \le r \le n, 1 \le x \le 3\))。

  

​   求一共有多少种满足所有限制的合法涂色方案。

  

​   答案对\(10^9+7\)取模。

    

  

  

Solution

  

​   首先要想到状态表示法,如何表示才能适应这些限制呢?由于是限制颜色种类数,可以考虑最早出现位置这类套路。

  

​   设\(f_{i,j,k}\)表示:当前走完\(1...i\),在\(i\)左边最靠右的、与\(i\)颜色不同的位置为\(j\),在\(j\)左边最靠右的、与\(i\)和\(j\)颜色不同的位置为\(k\)时,目前合法染色方案数是多少。

  

​   逐步计算\(f_1,f_2,...\)。

  

​   接下来考虑限制。考虑在转移的时候逐一枚举限制来判断新状态是否合法。

    

​   则总复杂度是\(\mathcal O(n^3m)\)的。还有3倍常数,显然不够优秀。

  

​   然而这只是臆想做法,具体我也没实现出来,因为枚举限制的时候,限制的区间和\(i,j,k\)的位置的关系实在太多,不好写。

  

​   实际上,对于一个\([l,r]\)的限制,它只需要去管\(i==r\)的那些状态是否合法即可。如果\(i<r\),那么显然还没有考虑的必要(都没填完\([l,r]\),考虑什么呢?)。如果\(r<i\)那么已经晚了。所以每个条件至多被枚举一次。

  

​   因此总复杂度是\(\mathcal O (n^2(n+m))\)的。

  

​   所以下次觉得枚举限制条件十分复杂且时间复杂度爆炸的时候,不妨想一想限制条件或许只针对特定对象才起效果或必要,这样就可以减少总枚举次数,优化复杂度。

  

​  

  

  

  

Code

  

#include <cstdio>
#include <algorithm>
#include <vector>
#define pb push_back
#define mp make_pair
using namespace std;
typedef pair<int,int> pii;
const int N=310;
const int MOD=1e9+7;
int n,m;
int f[N][N][N];
vector<pii> lis[N];
void readData(){
scanf("%d%d",&n,&m);
int l,r,x;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&l,&r,&x);
lis[r].pb(mp(l,x));
}
}
void dp(){
f[1][0][0]=1;
for(int i=1;i<=n;i++){
for(int d=0,sz=lis[i].size();d<sz;d++){
int l=lis[i][d].first,x=lis[i][d].second;
for(int j=0;j<i;j++)
for(int k=0;k<=(j-(j>0));k++){
if(x==1){
if(l<=j) f[i][j][k]=0;
}
else if(x==2){
if(l<=k||j<l) f[i][j][k]=0;
}
else{
if(k<l) f[i][j][k]=0;
}
}
}
if(i==n) break;
for(int j=0;j<i;j++)
for(int k=0;k<=(j-(j>0));k++)
if(f[i][j][k]){
(f[i+1][j][k]+=f[i][j][k])%=MOD;
(f[i+1][i][k]+=f[i][j][k])%=MOD;
(f[i+1][i][j]+=f[i][j][k])%=MOD;
}
}
int ans=0;
for(int j=0;j<n;j++)
for(int k=0;k<=(j-(j>0));k++)
(ans+=f[n][j][k])%=MOD;
ans=1LL*ans*3%MOD;
printf("%d\n",ans<0?ans+MOD:ans);
}
int main(){
readData();
dp();
return 0;
}

【ARC074e】RGB sequence的更多相关文章

  1. 【arc074e】RGB Sequence(动态规划)

    [arc074e]RGB Sequence(动态规划) 题面 atcoder 洛谷 翻译见洛谷 题解 直接考虑暴力\(dp\),设\(f[i][j][k][l]\)表示当前考虑到第\(i\)位,最后一 ...

  2. 【arc074e】RGB Sequence dp

    Description ​ 丰泽爷今天也在愉快地玩Minecraft! ​ 现在丰泽爷有一块1∗N1∗N的空地,每个格子按照顺序标记为11到NN.丰泽爷想要在这块空地上铺上红石块.绿宝石块和钻石块作为 ...

  3. 【XSY3209】RGB Sequence

    题目 传送门 解法 用\(f_{i, j, k}\)表示有\(i\)个红石块, \(j\)个绿宝石块, \(k\)个钻石块 可以转移到\(f_{p+1, j, k}\). \(f_{i, p+1,k ...

  4. 【arc071f】Infinite Sequence(动态规划)

    [arc071f]Infinite Sequence(动态规划) 题面 atcoder 洛谷 题解 不难发现如果两个不为\(1\)的数连在一起,那么后面所有数都必须相等. 设\(f[i]\)表示\([ ...

  5. 【BZOJ1367】[Baltic2004]sequence 左偏树

    [BZOJ1367][Baltic2004]sequence Description Input Output 一个整数R Sample Input 7 9 4 8 20 14 15 18 Sampl ...

  6. 【BZOJ3043】IncDec Sequence 乱搞

    [BZOJ3043]IncDec Sequence Description 给定一个长度为n的数列{a1,a2...an},每次可以选择一个区间[l,r],使这个区间内的数都加一或者都减一.问至少需要 ...

  7. 【C#】RGB,CMYK,HSB各种颜色表示的转换(转)

    [C#]RGB,CMYK,HSB各种颜色表示的转换   一.表示颜色的方式有很多种,如RGB,CMYK,HSB,Hex等等 1.RGB:这种表示颜色由三原色构成,通过红,绿,蓝三种颜色分量的不同,组合 ...

  8. T89353 【BIO】RGB三角形

    T89353 [BIO]RGB三角形 题解 对于这个题目有一个规律:  如果一个数列的长度为 3k+1(0<=k) 那么,这个数列最终缩放成的一个字母只和这个数列的首项,尾项有关 所以我们可以先 ...

  9. 【AGC025B】RGB Color

    [AGC025B]RGB Color 题面描述 Link to Atcoder Link to Luogu Takahashi has a tower which is divided into \( ...

随机推荐

  1. WebGL2系列之实例数组(Instanced Arrays)

    实例化数组 实例化是一种只调用一次渲染函数却能绘制出很多物体的技术,它节省渲染一个物体时从CPU到GPU的通信时间.实例数组是这样的一个对象,使用它,可以把原来的的uniform变量转换成attrib ...

  2. [C++]模板类和模板函数

    参考: C++ 中模板使用详解 C++模板详解 概念 为了避免因重载函数定义不全面而带来的调用错误,引入了模板机制 定义 模板是C++支持参数化多态的工具,使用模板可以使用户为类或者函数声明一种一般模 ...

  3. JavaScript学习笔记(八)—— 补

    第九章 最后的补充 一.Jquery简单阐述 JQuery是一个JavaScript库,旨在减少和简化处理DOM和添加视觉效果的JavaScript代码:使用时必须得添加库路径:学习路径:http:/ ...

  4. gcc 与 g++的区分较

    一:gcc与g++比较 误区一:gcc只能编译c代码,g++只能编译c++代码两者都可以,但是请注意:1.后缀为.c的,gcc把它当作是C程序,而g++当作是c++程序:后缀为.cpp的,两者都会认为 ...

  5. 从零开始的Python学习Episode 18——面向对象(1)

    类与对象 类即类别.种类,是面向对象设计最重要的概念,对象是特征与技能的结合体,而类则是一系列对象相似的特征与技能的结合体. 类的定义 class 类名: 属性1 属性2 def 方法(self,ar ...

  6. Qt 5.x 开发技巧

    出现unresolved external symbol "public: __thiscall Dialog::Dialog(class QWidget *) 或类似不太合理的错误时,可以 ...

  7. 图片人脸检测(OpenCV版)

    图片人脸检测 人脸检测使用到的技术是OpenCV,上一节已经介绍了OpenCV的环境安装,点击查看. 功能展示 识别一种图上的所有人的脸,并且标出人脸的位置,画出人眼以及嘴的位置,展示效果图如下: 多 ...

  8. Python20 - Day08

    异常处理 一.什么是异常? 异常就是程序运行时发生错误的信号(在程序出现错误时,则会产生一个异常,若程序没有处理他,则会抛出该异常,程序的运行也会停止) 错误分成两种: 1.语法错误 2.逻辑错误 二 ...

  9. ffmpeg——压缩mav格式音频

    今天偶然帮朋友压缩一个mav格式的音频.开始用压缩码率的方式,mav格式的音频体积一点都没变,查资料需要压缩音频文件的采样率和声道才能压缩mav格式的音频. 压缩要求是:将一个mav格式的音频文件,由 ...

  10. 第十章I/O

    系统级i/o 开始进程时的三个标准: 标准输入(描述符0):STDIN_FILENO 标准输出(描述符1):STDOUT_FILENO 标准错误(描述符2):STDERR_FILENO 文件位置: 从 ...