编辑文章 - 题解:P11557 [ROIR 2016] 有趣数字 (Day 2)

思路

记忆化搜索。很明显这题的输入一定是字符串。那么我们还需要写一个字符串减法,来计算左端点减一的值。

题目要求计算区间 l ∼ r l \sim r l∼r 内有趣的数字的数量。那么 1 ∼ r 1 \sim r 1∼r 的有趣数字的数量减去 1 ∼ l − 1 1 \sim l-1 1∼l−1 的数量就是区间内有趣数字的数量。

那我们可以用记忆化搜索的方式就行计算。记忆化搜索只需要三个参数。当前构造到的位置 n o w now now,上一个数字 l a s t last last,以及当前构造的数字是否顶格 l l l。

使用 l a s t last last 参数来判断当前数字是否按非递减顺序排列。使用 l l l 参数来判断当前数位上所能取最大值。

因为记忆化搜索是在每一位上构造符合要求的数字,所以当数字构造完毕后一定也符合题目要求,直接返回 1 1 1 即可。

不要忘记取模。

代码

cpp#include 复制代码
>#include<cstring>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#include<map>
#define ll long long
#define lhs printf("\n");
using namespace std;
const int N=3e5+10;
const int M=1e9+7;
const int inf=0x3f3f3f3f;
string l,r,a;
int a1[N],a2[N],ans[N];
ll dp[114][20][5];
string jian(string s1,string s2)
{
	string h;
	for(int i=0;i<s1.size();i++)
	{
		a1[s1.size()-1-i]=s1[i]-'0';
	}
	for(int i=0;i<s2.size();i++)
	{
		a2[s2.size()-1-i]=s2[i]-'0';
	}
	for(int i=0;i<max(s1.size(),s2.size());i++)
	{
		ans[i]=a1[i]-a2[i];
	}
	for(int i=0;i<max(s1.size(),s1.size());i++)
	{
		if (ans[i]<0)
		{
			ans[i]+=10;
			ans[i+1]--;
		}
	}
	int k=N-1;
	while((!ans[k]) and  k>0)
	{
		k--;	
	}
	for(int i=k;i>=0;i--)
	{
		char x=char(ans[i]+48);
		h+=x;
	}
	return h;
}
ll dfs(int now,int last,int l)
{
	if(now==a.size())
	{
		return 1;
	}
	if(dp[now][last][l]!=-1)
	{
		return dp[now][last][l];
	}
	int k=int(a[now])-48;
	int b=l ? k : 9;
	ll ans=0;
	for(int i=0;i<=b;i++)
	{
		if(i>=last)
		{
			ans+=dfs(now+1,i,l and i==b);
			ans%=M;
		}
	} 
	return dp[now][last][l]=ans;
}
ll solve(string x)
{
	memset(dp,-1,sizeof dp);
	a.clear();
	a+=x;
	return dfs(0,0,1);
} 
int main()
{
	cin>>l>>r;
	cout<<(solve(r)-solve(jian(l,"1"))+M)%M;//减法取模要+MOD
	return 0;
}
相关推荐
森焱森23 分钟前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack2 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客3 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠3 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988944 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼4 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield5 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦5 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl5 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder5 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c