HDU_5230_DP
http://acm.hdu.edu.cn/showproblem.php?pid=5230
有初始值c,给你1~n的数,输入c+一些数,使得结果在l~r的范围内,输出方案数,注意每种方案中每个数只能使用一次。
可以直接令l和r减去c,便成了分解l~r内的数,求分解方案。
dp[i][j]表示i个数组成j的方案数,根据j最大值推出i最大值,有状态方程dp[i][j] = dp[i][j-i]+dp[i-1][j-i]推出每一个值,最后求出答案即可。
dp[i][j-i]表示相同数量,但每个数都减去一的方案,另外考虑到该方案可以含有1,也就是dp[i-1][j-i]。
另外注意每次要mod一下,于是有了以下代码。
#include<iostream>
#include<cstdio>
#include<cstring>
#define LL long long
#define MOD 998244353
using namespace std; LL n,c,l,r,dp[][]; int main()
{
int T;
scanf("%d",&T);
while(T--)
{
LL ans;
memset(dp,,sizeof(dp));
scanf("%d%d%d%d",&n,&c,&l,&r);
l -= c;
r -= c;
if(l) ans = ;
else ans = ;
dp[][] = ;
for(int i = ;i*(i+)/ <= r;i++)
{
for(int j = i*(i+)/;j <= r;j++)
{
dp[i][j] = (dp[i][j-i]+dp[i-][j-i])%MOD;
if(j >= l)
{
ans = (ans+dp[i][j])%MOD;
}
}
}
printf("%lld\n",ans);
}
return ;
}
然而内存竟然超了,于是改进,使用2个数组轮流交替,得出最终答案。
#include<iostream>
#include<cstdio>
#include<cstring>
#define LL long long
#define MOD 998244353
using namespace std; LL n,c,l,r,dp[][]; int main()
{
int T;
scanf("%d",&T);
while(T--)
{
LL ans;
memset(dp,,sizeof(dp));
scanf("%d%d%d%d",&n,&c,&l,&r);
l -= c;
r -= c;
if(l) ans = ;
else ans = ;
dp[][] = ;
for(int i = ;i*(i+)/ <= r;i++)
{
for(int j = i*(i+)/;j <= r;j++)
{
dp[i%][j] = (dp[i%][j-i]+dp[(i+)%][j-i])%MOD;
if(j >= l)
{
ans = (ans+dp[i%][j])%MOD;
}
}
memset(dp[(i+)%],,sizeof(dp[(i+)%]));
}
printf("%lld\n",ans);
}
return ;
}
HDU_5230_DP的更多相关文章
随机推荐
- 小小知识点(二十六)关于5G发展的28个核心问题,来自华为内部的深度解读
本文来自微信公众号“腾讯深网”(ID:qqshenwang),作者 马关夏.36氪经授权转载. 一.5G先进性与行业应用 1.5G到底是什么?和4G比有什么不一样? 从国际电信联盟(ITU)的定义来看 ...
- Salesforce LWC学习(十) 前端处理之 list 处理
本篇参看:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array list是我们经 ...
- vue 路由模块化
第一. 在 router 文件夹下 新建个个模块的文件夹,存放对应的路由js文件 如图1: 第二.修改router文件夹下的index.js 如图2 三.在main.js 修改如下代码 图3
- Sample Code之Take a screenshot of a SceneView
周末事情太多了,以后就工作日发布随笔吧.周末的话,看心情,也许也会发~ 今天的实例代码解析是Take a screenshot of a SceneView,也就是获取快照,话不多说,进入正题. 首先 ...
- mongo repository
using MongoDB.Driver; namespace Dben.Invoice.Repository { /// <summary> /// 仓储基类 /// </summ ...
- python命名空间(namespace)
命名空间: 每一个作用域变量存储的位置,或者解释为 存储作用域中变量的字典. 作用: 获取想查看某个作用域中的变量名.变量值. 使用方法: locals() #当前命名空间 1. 效果图: 2. 代 ...
- 解决el-tree lazy懒加载时,连续勾选前两个子节点后第二次进入默认选中时,将父节点也勾选的问题
在用到el-tree的懒加载和默认勾选功能时,若第一次勾选前几个连续节点,第二次进入默认勾选时,由于el-tree子节点尚未完全加载(只加载出来前几个),默认勾选已经开始(已加载出来的子节点被默认勾选 ...
- GitHub进阶之利用Git远程仓库篇
#在上一篇文章,相信大家对GitHub已经有了一个基础的理解 接下来我们来学习一下如何利用git来远程仓库 一,git是什么 git:一个免费的开源版本控制软件 用途:利用Git管理GitHub上的代 ...
- stars-one原创工具——蓝奏云批量下载工具
一款可以批量下载蓝奏云分享的文件夹下的所有文件 基于HtmlUnit和okhttp开源库,所以打包后的jar包文件有点大 蓝奏云下载地址 github地址 需求 之前找电子书资源的时候,网友分享的蓝奏 ...
- django 数据库中的表生成model
https://blog.csdn.net/weixin_34405354/article/details/93582647 还没有证实是否有效