题面

传送门

分析

这种计数问题,要不是纯数学推公式,要不就是dp

先处理出[l,r]中除3余0,1,2的数的个数,记为cnt0,cnt1,cnt2

设\(dp[i][j]\)表示前i个数的和除3余j的个数

则\(dp[1][0]=cnt0,dp[1][1]=cnt1,dp[1][2]=cnt2\)

最终答案为\(dp[n][0]\)

状态转移方程为

\(dp[i][0]=dp[i-1][0]*cnt0+dp[i-1][1]*cnt2+dp[i-1][2]*cnt1\)

\(dp[i][1]=dp[i-1][1]*cnt0+dp[i-1][2]*cnt2+dp[i-1][0]*cnt1\)

\(dp[i][2]=(dp[i-1][2]*cnt0+dp[i-1][0]*cnt2+dp[i-1][1]*cnt1\)

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 200005
#define mod 1000000007
using namespace std;
int n;
long long l,r;
long long cnt0,cnt1,cnt2;
long long dp[maxn][3];
int solve(int x,int k){
int t;
if(x%3==0) t=3;
else t=x%3;
return (x-t)/3+(x%3==k);
}
int main(){
scanf("%d %I64d %I64d",&n,&l,&r);
int l1,l2,l3;
l1=l%3;
l2=(r+1-l);
l3=l2%3;
l2=l2/3;
cnt1=cnt2=cnt0=l2;
if(l3==1){
if(l1==1) cnt1++;
else if(l1==2) cnt2++;
else cnt0++;
}
if(l3==2){
cnt1++,cnt2++,cnt0++;
if(l1==1) cnt0--;
else if(l1==2) cnt1--;
else cnt2--;
}
dp[1][0]=cnt0;
dp[1][1]=cnt1;
dp[1][2]=cnt2;
for(int i=2;i<=n;i++){
dp[i][0]=(dp[i-1][0]*cnt0%mod+dp[i-1][1]*cnt2%mod+dp[i-1][2]*cnt1)%mod;
dp[i][1]=(dp[i-1][1]*cnt0%mod+dp[i-1][2]*cnt2%mod+dp[i-1][0]*cnt1)%mod;
dp[i][2]=(dp[i-1][2]*cnt0%mod+dp[i-1][0]*cnt2%mod+dp[i-1][1]*cnt1)%mod;
}
printf("%I64d\n",dp[n][0]);
}

最新文章

  1. [译]AngularJS中DOM操作
  2. 【记录】vmware fusion 7 windows 10 unidentified network
  3. 常用的HTTP状态代码
  4. Linux下如何修改Apache根目录
  5. C/C++面试题总结
  6. Linux Network Related Drive
  7. nginx.conf文件说明
  8. codeforces 422A A. Borya and Hanabi(暴力)
  9. jquery.autocomplete.js 插件的自定义搜索规则
  10. Spring Data JPA Tutorial Part Nine: Conclusions(未翻译)
  11. .NET下的延迟加载
  12. 【形式化方法:VDM++系列】4.VDM实战1——铁路费用计算
  13. 【实习记】2014-08-10(上)代码跟踪git的想法+归并排序的debug过程
  14. [项目记录] 用c语言完成的一个学生成绩管理系统
  15. javascript 手势(swipeLeft,swipeRight)滑动中使用css3动画卡顿,开启硬件加速
  16. [Codeforces178F2]Representative Sampling
  17. Yii2 数据缓存/片段缓存/页面缓存/Http缓存
  18. android弹出对话框
  19. Android 请求运行时权限
  20. 【C#】使用Json.NET(newtonsoft)解析Json

热门文章

  1. 01.Windows2008R2系统禁启SMBv1服务命令
  2. nodejs http服务器简单搭建
  3. CreateProcessAsUser 服务调用
  4. centeros 安装maven 私服
  5. java int整数相乘溢出
  6. 【leetcode】1037. Valid Boomerang
  7. 第六周作业—N42-虚怀若谷
  8. WEB前端开发的思考与感悟
  9. Nginx负载均衡与反向代理—《亿级流量网站架构核心技术》
  10. 学习日记3、投机取巧使两个表的数据同时在一个treeGrid中显示