UVA - 11361 Investigating Div-Sum Property(数位dp/记忆化搜索板子)

题目:https://vjudge.net/problem/UVA-11361

**大意**:
思路:数位dp,用记忆化搜索写,dp[pos][i][j][limit] 代表剩余有pos位,每位上的数字和模k 等于i, 当前总数值模k等于j,limit代表限制位。
本题还要注意的是当k》100时 答案为0,要加个特判,不然k=100000会导致内存不够。

代码(含注释):

#include<bits/stdc++.h>
#define INF 0x3f3f3f3f3f3f3f3f
#define inf 0x3f3f3f3f
#define FILL(a,b) (memset(a,b,sizeof(a)))
#define re register
#define lson rt<<1
#define rson rt<<1|1
#define lowbit(a) ((a)&-(a))
#define ios std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);
#define fi first
#define rep(i,n) for(int i=0;(i)<(n);i++)
#define rep1(i,n) for(int i=1;(i)<=(n);i++)
#define se secondusing namespace std;
typedef long long  ll;
typedef unsigned long long  ull;
typedef pair<int,int > pii;
int dx[4]= {-1,1,0,0},dy[4]= {0,0,1,-1};
const ll mod=1000000000;
const ll N =1e5+10;
const double eps = 1e-4;
const double pi=acos(-1);
ll gcd(int a,int b){return !b?a:gcd(b,a%b);}
ll dp[20][100][11000][5];
int sum[100];
int l,r,k;
int idx;
ll dfs(int pos,int i,int j,int limit)
{if(pos==0){if(i==0&&j==0)//两者都成立时 才找到一个答案return 1;return 0;}if(dp[pos][i][j][limit]>=0) return dp[pos][i][j][limit];//之前已经搜过了ll ans=0;for(int q=0;q<(limit?sum[pos]:10);q++){ans+=dfs(pos-1,(i+q)%k,(j*10+q*)%k,0);//pos位的数比sum【pos】小,下一位没有limit}if(limit)//有limit时pos位选择最大的那个,下一位也应该有limit{ans+=dfs(pos-1,(sum[pos]+i)%k,(j*10+sum[pos])%k,1);}return  dp[pos][i][j][limit]=ans;
}
ll work(int x)//把每一位上的数字保存起来
{idx=0;while(x>0){sum[++idx]=x%10;x/=10;}return dfs(idx,0,0,1);
}
void slove()
{cin>>l>>r>>k;if(k>100) {//大于100时直接输出cout<<0<<endl;return;}FILL(dp,-1);cout<<work(r)-work(l-1)<<endl;//经典算法了,两前缀相减等于区间和。// cout<<fixed<<setprecision(7)<<dp[n]<<endl;
}
int main()
{iosint t=1;cin>>t;fun();while(t--){slove();}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315393.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#并发编程之异步编程(三)

写在前面本篇是异步编程系列的第三篇&#xff0c;本来计划第三篇的内容是介绍异步编程中常用的几个方法&#xff0c;但是前两篇写出来后&#xff0c;身边的朋友总是会有其他问题&#xff0c;所以决定再续写一篇&#xff0c;作为异步编程(一)和异步编程(二)的补充。本篇内容主要…

UVA - 10253 Series-Parallel Networks(递推式、记忆化搜索写法)

题目&#xff1a;UVA-10253 题目翻译&#xff08;来自蓝书&#xff09;&#xff1a; 串并联网络有两个端点&#xff0c;一个叫源&#xff0c;一个叫汇&#xff0c;递归定义如下&#xff1a; &#xff08;1&#xff09; 一条单独的边是串并联网络。 &#xff08;2&#xff09;…

C#规范整理·泛型委托事件

基于泛型&#xff0c;我们得以将类型参数化&#xff0c;以便更大范围地进行代码复用。同时&#xff0c;它减少了泛型类及泛型方法中的转型&#xff0c;确保了类型安全。委托本身是一种引用类型&#xff0c;它保存的也是托管堆中对象的引用&#xff0c;只不过这个引用比较特殊&a…

Abp v0.18.0 新版本: MVC Module 启动模板

0.18.0将于近期发布, 本文内容针对于0.18.0版本.MVC模块启动模板可用此模板开发基于模块开发最佳实践和约定的可复用 应用程序模块 . 它同样适用于开发微服务.如何开始?你可以使用ABP CLI创建基于此启动模板的新项目,或者你也可以在入门页面创建并下载项目. 在这里我们使用CLI…

Consul-template+nginx实现自动负载均衡

前言consul-template 是 Consul 的一个守护程序&#xff0c;使用 consul-template 可以方便快速的实现对 Consul Key/Value 存储系统的访问&#xff0c;可以从 KV 系统中读取数据、监视变动、同步本地文件&#xff1b;还可以在执行模板更新的同时&#xff0c;执行本地系统命令&…

Codeforces Round #613 (Div. 2) E. Delete a Segment 离散化

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 我们考虑将区间内的位置都111&#xff0c;之后求区间段数就可以转换成求&#xff0c;连续不为000的区间段数&#xff0c;由于范围有[−1e9,1e9][-1e9,1e9][−1e9,1e9]的级别&#xff0c;所…

是时候挥别 SQL Server 2008 了

微软 宣布将于 2019 年 7 月终止对 SQL Server 2008 和 2008 R2 的支持&#xff0c;使用 SQL Server 2008 的公司应该认真开始考虑下一步了。本文引用了一家数字化转型咨询公司高级顾问对此的分析&#xff0c;并提供了一些解决方案和注意事项。如果你还在使用 微软 2008 版的 S…

领域驱动设计,让程序员心中有码(八)

领域驱动是十五年前&#xff0c;由Eric Evans提出的解决软件工程复杂性问题的方法&#xff0c;作者从自己多年软件开发的角度出发&#xff0c;通过引入领域驱动设计的概念以及一系列战略设计模式和战术方法&#xff0c;为混沌的软件开发领域带来了一缕阳光。在过去的许多年&…

H - Great Cells Gym - 101194H(数学推导/思维)

VJ地址 ps&#xff1a;在训练时写这道题 差点被送走了 我们可以发现给出的公式可以转化这样 这个就不说了&#xff0c;就是k^(nm)所以排列的可能; 然后我们要重点观察这个公式&#xff0c;可以发现g * Ag&#xff08;方案数 * good点的数量&#xff09; 可以意味这组成一个…

基于Dapper的开源Lambda扩展,且支持分库分表自动生成实体之基础

LnskyDB是基于Dapper的Lambda扩展,支持按时间分库分表,也可以自定义分库分表方法.而且可以T4生成实体类免去手写实体类的烦恼.文档地址: https://liningit.github.io/LnskyDB/开源地址: https://github.com/liningit/LnskyDBnuget地址: https://www.nuget.org/packages/LnskyDB…

技术达人“创造营”官宣:Microsoft Learn 学习平台C位出道

真的大神敢于直面随时更新的IT技术你是要做一个平平无奇的“合格员工”&#xff1f;还是要做一个博古通今的“江湖百晓生”&#xff1f;转型变化&#xff0c;是时代的氛围面对日新月异的技术更新一不留神&#xff0c;就会沦落为“技术支持滞后人员”在微软&#xff0c;有这样一…

P2839 [国家集训队]middle 二分 + 主席树 在值域上建区间

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 我们先解决怎么判断中位数的问题&#xff0c;我们可以二分一个midmidmid&#xff0c;将<mid<mid<mid的值都变成−1-1−1&#xff0c;其他的数都变成111&#xff0c;那么当全部的和…

读再多书都没觉得自己变强?试试我这“5年陈”的方法

这里是Z哥的个人公众号每周五早8点 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「76」篇原创敬上4800字巨献奉上hi&#xff0c;大家好。三周过去了&#xff0c;上次教你的几个「速读」技巧练习的怎么样了&#xff1f;上周&#xff0c;已经有不少小伙们开始催…

Educational Codeforces Round 77 (Rated for Div. 2) C. Infinite Fence 数论

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 碰到这样的题肯定是先写几个找找规律了&#xff0c;随便写几个就可以发现是以lcm(a,b)lcm(a,b)lcm(a,b)为一个循环&#xff0c;所以我们只需要在一个周期lcm(a,b)lcm(a,b)lcm(a,b)中求最长…

C# 内存的理解 通俗说

一.概念堆栈是什么&#xff1f;在说堆栈之前&#xff0c;先说说内存是神马&#xff1f;内存&#xff1a;程序在运行的过程&#xff0c;电脑需要不断通过CPU进行计算&#xff0c;这个计算的过程会读取并产生运算的数据&#xff0c;这些数据需要一个存储容器存放。这个容器&#…

P3899 [湖南集训]谈笑风生 主席树解决二维数点

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 由于a,ba,ba,b都比ccc厉害&#xff0c;那么a,ba,ba,b一定是某个是某个的祖先。那么就分为两种情况了&#xff1a; (1)(1)(1) bbb在aaa上面&#xff0c;约定depth[1]1depth[1]1depth[1]1&am…

打造 .NET Core 链接转发服务

我最近使用 .NET Core 2.2 造了个名为"Link Forwarder" &#xff08;链接转发器&#xff09;的 URL 转发服务&#xff0c;并已开源。目前预览版已部署到我的子域"go.edi.wang"。本文将分享我如何构建这个项目&#xff0c;以及我学到的东西。为了帮助大家了…

P3293 [SCOI2016]美味 主席树 + 伪01trie

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 看到异或的话&#xff0c;很容易想到用01trie来贪心的搞&#xff0c;但是这个题涉及区间问题&#xff0c;直接搞的话需要将[l,r][l,r][l,r]的数都插入trie里面&#xff0c;这样的复杂度显然…

Abp 0.18.0 正式发布! -ABP CLI,新模板和其他功能

ABP CLI, v0.18版本新模板和其他功能ABP v0.18已发布, 包含解决的80个issue, 550次提交.网站更改abp.io网站完全更新以突出ABP框架的目标和重要功能.文档和博客网址也会更改&#xff1a;abp.io/documents移至docs.abp.io.abp.io/blog转移到blog.abp.io.ABP CLIABP CLI(命令行界…

短信验证码“最佳实践”

1、背景年初&#xff0c;从外地转移阵地到西安&#xff0c;转眼已两个多月。很久不写业务代码了&#xff0c;到了新公司&#xff0c;条件恶劣到前所未有&#xff0c;从需求&#xff0c;设计&#xff0c;架构&#xff0c;实现&#xff0c;实施&#xff0c;测试&#xff0c;bug修…