[Arc074E] RGB Sequence

Description

今天也在愉快地玩Minecraft!现在MM有一块1?N的空地,每个格子按照顺序标记为1到N。MM想要在这块空地上铺上红石块、绿宝石块和钻石块作为装饰。每个格子只能选择一种方块。MM有自己的审美标准。他定下了M条规定,每条规定形如(li,ri,xi),表示闭区间[li,ri]中,需要有恰好xi种不同的方块。MM觉得这个任务实在是太简单了,于是把它交给了你,但是你发现有太多种方式可以满足MM的审美需求了!于是你希望先知道,一共有多少铺方块的方法,可以满足MM的审美需求?答案对109+7取模

Input

第一行两个整数,N,M

接下来M行,每行三个整数li,ri,xi

Output

一个整数,对109+7取模后的答案

Sample Input

Case 1:3 1

1 3 3

Case 2:4 2

1 3 1

2 4 2

Case 3:1 3

1 1 1

1 1 2

1 1 3

Case 4:8 10

2 6 2

5 5 1

3 5 2

4 7 3

4 4 1

2 3 1

7 7 1

1 5 2

1 7 3

3 4 2

Sample Output

Case 1:6

Case 2:6

Case 3:0

Case 4:108

HINT

1≤N,M≤300

1≤li≤ri≤N

1≤xi≤3

试题分析

设\(f{i,j,k}\)表示填到第i位,另外两种颜色最后一次涂在\(\{j,k\}\)的方案数。

在右端点判断不合法情况,转移即可。

  1. #include<iostream>
  2. #include<cstring>
  3. #include<cstdio>
  4. #include<vector>
  5. #include<algorithm>
  6. using namespace std;
  7. #define LL long long
  8. inline int read(){
  9. int x=0,f=1; char c=getchar();
  10. for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
  11. for(;isdigit(c);c=getchar()) x=x*10+c-'0';
  12. return x*f;
  13. }
  14. const int INF = 2147483600;
  15. const int MAXN = 100010;
  16. const int Mod = 1e9+7;
  17. int N,M;
  18. struct data{
  19. int l,x; data(int ll=0,int xx=0){
  20. l=ll; x=xx;
  21. }
  22. }; vector<data> vec[MAXN+1];
  23. inline bool check(int i,int j,int k){
  24. for(int l=0;l<vec[i].size();l++){
  25. int cnt=1; if(vec[i][l].l<=j) ++cnt;
  26. if(vec[i][l].l<=k) ++cnt;
  27. if(cnt!=vec[i][l].x) return false;
  28. } return true;
  29. }int f[301][301][301];
  30. int main(){
  31. //freopen(".in","r",stdin);
  32. //freopen(".out","w",stdout);
  33. N=read(),M=read();
  34. for(int i=1;i<=M;i++){
  35. int l=read(),r=read(),x=read();
  36. vec[r].push_back(data(l,x));
  37. } f[0][0][0]=1;
  38. for(int i=0;i<N;i++){
  39. for(int j=0;j<(i==0?1:i);j++){
  40. for(int k=0;k<(j==0?1:j);k++){
  41. if(!check(i,j,k)){f[i][j][k]=0; continue;}
  42. (f[i+1][i][j]+=f[i][j][k])%=Mod;
  43. (f[i+1][i][k]+=f[i][j][k])%=Mod;
  44. (f[i+1][j][k]+=f[i][j][k])%=Mod;
  45. }
  46. }
  47. } int ans=0;
  48. for(int i=0;i<=N;i++){
  49. for(int j=i+1;j<=N;j++)
  50. if(check(N,j,i)) (ans+=f[N][j][i])%=Mod;
  51. }if(check(N,0,0)) (ans+=f[N][0][0])%=Mod;
  52. printf("%d\n",ans);
  53. return 0;
  54. }

[Arc074E] RGB Sequence的更多相关文章

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

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

  2. 【ARC074e】RGB sequence

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

  3. 【arc074e】RGB Sequence dp

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

  4. AtCoder - 2567 RGB Sequence

    Problem Statement There are N squares arranged in a row. The squares are numbered 1, 2, …, N, from l ...

  5. AT2567-[ARC074C]RGB Sequence【dp】

    正题 题目链接:https://www.luogu.com.cn/problem/AT2567 题目大意 长度为\(n\)的包含三种颜色\(RGB\)的序列,\(m\)个限制\([l,r,k]\)表示 ...

  6. AT2567 RGB Sequence dp

    正解:计数dp 解题报告: 传送门! umm其实我jio得dp的题目的话就难在思想昂,,,知道状态知道转移就不难辣QAQ 所以就不说别的了直接写下思路放下代码就over辣QAQ 最基础的思想就是f[i ...

  7. [AT2567] [arc074_c] RGB Sequence

    题目链接 AtCoder:https://arc074.contest.atcoder.jp/tasks/arc074_c 洛谷:https://www.luogu.org/problemnew/sh ...

  8. ARC074 E RGB Sequence DP

    ---题面--- 题解: 首先,有一个不太直观的状态,f[i][j][k][l]表示DP到i位,三种颜色最后出现的位置分别是j, k, l的方案数.因为知道了三种颜色最后出现的位置,因此也可以得知以当 ...

  9. AtCoder Regular Contest 074 E:RGB Sequence

    题目传送门:https://arc074.contest.atcoder.jp/tasks/arc074_c 题目翻译 给你一行\(n\)个格子,你需要给每个格子填红绿蓝三色之一,并且同时满足\(m\ ...

随机推荐

  1. 炒鸡简单的canvas粒子(山东数漫江湖)

    位图的canvas一直不会被svg比下去的原因了. 俗话说,须弥芥子,是大小之说,也有以小见大之说,颗颗粒子,足以构建宏大效果. 这是一篇炒鸡简单的canvas粒子教程,主要是讲如何粒子特效的原理,一 ...

  2. 新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛) F.猴子排序的期望

    题目链接:https://www.nowcoder.com/acm/contest/116/F 题目描述 我们知道有一种神奇的排序方法叫做猴子排序,就是把待排序的数字写在卡片上,然后让猴子把卡片扔在空 ...

  3. 对vue中 默认的 config/index.js:配置的详细理解 -【以及webpack配置的理解】-config配置的目的都是为了服务webpack的配置,给不同的编译条件提供配置

    当我们需要和后台分离部署的时候,必须配置config/index.js: 用vue-cli 自动构建的目录里面  (环境变量及其基本变量的配置) var path = require('path') ...

  4. Msfvenom学习总结-MSF反弹webshell

    1.    –p (- -payload-options) 添加载荷payload. 载荷这个东西比较多,这个软件就是根据对应的载荷payload生成对应平台下的后门,所以只有选对payload,再填 ...

  5. HTML综合实例【月福首页】

    1. 首页的布局结构 2. 排版的准备工作 网站的素材:与当前网页放在一起. 创建一个html文件,来进行排版. 网页的背景色 确定主页的宽度:778px 3. HTML注释 <!-- 注释内容 ...

  6. java===java基础学习(10)---对象构造

    重载 如果多个方法有相同的名字,不同的参数,便产生了重载.编译器必须挑选出具体执行哪个方法,他通过用各个方法给出的参数类I型那个与特定方法调用所使用的值类型进行匹配来挑选出相应的方法.如果编译器找不到 ...

  7. 看jquery3.3.1学js类型判断的技巧

    需要预习:call , typeof, js数据类型 1. isFunction中typeof的不靠谱 源码: var isFunction = function isFunction( obj ) ...

  8. [hadoop][会装]hadoop ha模式安装

    1.简介 2.X版本后namenode支持了HA特性,使得整个文件系统的可用性更加增强. 2.安装前提 zookeeper集群,zookeeper的安装参考[hadoop][会装]zookeeper安 ...

  9. FineReport——自定义控件实现填报提交事件和校验

    在报表内部或者在引用报表的HTML页面,定义一个按钮标签,通过FR提供的方法实现提交功能. <button onclick="_g('${sessionID}').writeRepor ...

  10. hadoop3.1 hdfs的api使用

    1.开发环境配置 1.1eclipse导入插件 1.2.配置hadoop的引用路径 window--->preference --->