牛客小白月赛8 - E - 诡异数字 数位DP
题意:
求区间中,满足限制条件的数字的个数。 限制条件就是某些数字不能连续出现几次。
思路:
比较裸的数位DP, DP数组开一个dp【len】【x】【cnt】 表示长度为len,x这个数字连续出现cnt次的个数。
#include <iostream>
#include <algorithm>
#include <cstring>
#include <string>
#include <cstdio>
typedef long long ll; using namespace std; const int mod = ; int dp[][][];
int cnt[],shu[]; ll swdp(int len, int x,int sum, bool limit){
if(len == )return ;
if(!limit && dp[len][x][sum]) return dp[len][x][sum]; int mx = limit ? shu[len] : ;
ll res = ;
for(int i=; i<=mx; i++){
if(x==i && sum + > cnt[x])continue;
if(x==i) res = (res + swdp(len-,x,sum+, limit && i == mx)) % mod;
else res = (res + swdp (len-,i,,limit && i == mx))%mod; }
return limit?res:dp[len][x ][sum] = res;
} ll solve(ll x){
if(x == -)return ;
int k = ;
while(x > ){
shu[++k] = x % ;
x /= ;
}
return swdp(k, , , true);
}
int main(){
int t,n; scanf("%d", &t);
ll le,ri;
while(t--) {
for(int i=; i<=; i++)cnt[i] = ;
memset(dp,,sizeof(dp));
scanf("%lld%lld%d", &le, &ri, &n);
while(n--) {
int x,len;
scanf("%d%d", &x, &len);
cnt[x] = min(cnt[x] , len);
} printf("%lld\n", (solve(ri) - solve(le-) + mod)%mod);
} return ;
}
牛客小白月赛8 - E - 诡异数字 数位DP的更多相关文章
- 牛客小白月赛1   G	あなたの蛙は旅⽴っています【DP】
		题目链接 https://www.nowcoder.com/acm/contest/85/G 思路 按照题解上的方式 存取数据 然后DP一下 就可以了 AC代码 #include <cstdio ... 
- 树的最长链-POJ 1985 树的直径(最长链)+牛客小白月赛6-桃花
		求树直径的方法在此转载一下大佬们的分析: 可以随便选择一个点开始进行bfs或者dfs,从而找到离该点最远的那个点(可以证明,离树上任意一点最远的点一定是树的某条直径的两端点之一:树的直径:树上的最长简 ... 
- 牛客网 牛客小白月赛5 I.区间 (interval)-线段树 or 差分数组?
		牛客小白月赛5 I.区间 (interval) 休闲的时候写的,但是写的心情有点挫,都是完全版线段树,我的一个队友直接就水过去了,为啥我的就超内存呢??? 试了一晚上,找出来了,多初始化了add标记数 ... 
- 牛客小白月赛18 Forsaken给学生分组
		牛客小白月赛18 Forsaken给学生分组 Forsaken给学生分组 链接:https://ac.nowcoder.com/acm/contest/1221/C来源:牛客网  Forsaken有 ... 
- 牛客小白月赛18 Forsaken喜欢数论
		牛客小白月赛18 Forsaken喜欢数论 题目传送门直接点标题  Forsaken有一个有趣的数论函数.对于任意一个数xxx,f(x)f(x)f(x)会返回xxx的最小质因子.如果这个数没有最小质 ... 
- 牛客小白月赛19 E 「火」烈火燎原 (思维,树)
		牛客小白月赛19 E 「火」烈火燎原 (思维,树) 链接:https://ac.nowcoder.com/acm/contest/2272/E来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空 ... 
- 【牛客小白月赛21】NC201604 Audio
		[牛客小白月赛21]NC201604 Audio 题目链接 题目大意: 给出三点 ,求到三点距离相等的点 的坐标. 解析 考点:计算几何基础. 初中蒟蒻表示不会什么法向量.高斯消元..qwq 方法一: ... 
- 【牛客小白月赛21】NC201605 Bits
		[牛客小白月赛21]NC201605 Bits 题目链接 题目描述 Nancy喜欢做游戏! 汉诺塔是一个神奇的游戏,神奇在哪里呢? 给出3根柱子,最开始时n个盘子按照大小被置于最左的柱子. 如果盘子数 ... 
- 牛客小白月赛16 小石的妹子  二分  or  线段树
		牛客小白月赛16 这个题目我AC之后看了一下别人的题解,基本上都是线段树,不过二分也可以. 这个题目很自然就肯定要对其中一个进行排序,排完序之后再处理另外一边,另一边记得离散化. 怎么处理呢,你仔细想 ... 
随机推荐
- PHP 防范xss攻击(转载)
			XSS 全称为 Cross Site Scripting,用户在表单中有意或无意输入一些恶意字符,从而破坏页面的表现! 看看常见的恶意字符XSS 输入: 1.XSS 输入通常包含 JavaScript ... 
- 【Spring】No converter found for return value of type: class java.util.ArrayList
			错误信息: org.springframework.http.converter.HttpMessageNotWritableException: No converter found for ret ... 
- [重磅开源] 比SingleR更适合的websocket 即时通讯组件---ImCore开源了
			有感而发 为什么说 SignalR 不合适做 IM? IM 的特点必定是长连接,轮训的功能用不上. 因为它是双工通讯的设计,用hub.invoke发送命令给服务端处理业务,其他就和 ajax 差不多, ... 
- Mysql的行级锁与表级锁
			在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足. 在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引擎).表级锁(MYISAM ... 
- 基于Spring框架应用的权限控制系统的研究和实现
			摘 要: Spring框架是一个优秀的多层J2EE系统框架,Spring本身没有提供对系统的安全性支持.Acegi是基于Spring IOC 和 AOP机制实现的一个安全框架.本文探讨了Acegi安全 ... 
- Spring Cloud 之 Stream.
			一.简介 Spring Cloud Stream 是一个用来为微服务应用构建消息驱动能力的框架. Spring Cloud Stream 为一些供应商的消息中间件产品(目前集成了 RabbitMQ 和 ... 
- java文字转语音播报功能的实现方法
			java文字转语音播报功能的实现方法 一.pom.xml引入jar包依赖 <!-- https://mvnrepository.com/artifact/com.jacob/jacob 文字转语 ... 
- 【原创实践】U大师启动安装windows XP
			1:使用U大师3.0版制作启动U盘,拷贝windows xp或者win7的原版安装iso(zh-hans_windows_xp_professional_with_service_pack_3_x86 ... 
- Vue 中使用 typescript
			Vue 中使用 typescript 什么是typescript typescript 为 javaScript的超集,这意味着它支持所有都JavaScript都语法.它很像JavaScript都强类 ... 
- EFCore + MySql codeFirst 迁移 Migration出现的问题
			第二次使用Migration update-database的时候出现以下错误: System.NotImplementedException: The method or operation is ... 
