美丽的项链

链接:https://ac.nowcoder.com/acm/contest/315/F
来源:牛客网

妞妞参加了Nowcoder Girl女生编程挑战赛, 但是很遗憾, 她没能得到她最喜欢的黑天鹅水晶项链。

于是妞妞决定自己来制作一条美丽的项链。一条美丽的项链需要满足以下条件:

1、需要使用n种特定的水晶宝珠

2、第i种水晶宝珠的数量不能少于li颗, 也不能多于ri颗

3、一条美丽的项链由m颗宝珠组成

妞妞意识到满足条件的项链种数可能会很多, 所以希望你来帮助她计算一共有多少种制作美丽的项链的方案。

输入描述:
输入包括n+1行, 第一行包括两个正整数(1 <= n <= 20, 1 <= m <= 100), 表示水晶宝珠的种数和一条美丽的项链需要的水晶宝珠的数量。

接下来的n行, 每行两个整数li, ri(0 <= li <= ri <= 10), 表示第i种宝珠的数量限制区间。

输出描述:
输出一个整数, 表示满足限定条件的方案数。保证答案在64位整数范围内。
示例1
输入

3 5
0 3
0 3
0 3
输出

12
备注:
对于两种方案,当有任意一种水晶宝珠个数不同,就视为两种不同方案。

 

   本题是一个动态规划的题,dp[i][j]表示前i种水晶宝珠能凑成j颗的方法数,当前i的宝珠颗数为li~ri,所以那么为了凑齐j颗,需要保证前i-1种宝珠需要凑齐多少颗(利用j与li、ri进行简单计算求得),求得一个范围都可以,那么只需要加上前i-1宝珠所有能满足需求的方案数。代码如下:
 

#include<iostream>
#include<cstring>
using namespace std;
int main()
{
	int n,m;
	cin >> n >> m;
	int l[25],r[25];
	for(int i=1;i<=n;i++){
		cin >> l[i] >>r[i] ;
	}
	long long dp[25][105];
	memset(dp,0,sizeof(dp)) ;
	for(int i=l[1];i<=r[1];i++)
		dp[1][i] = 1;
	for(int i=2;i<=n;i++){
		for(int j=0;j<=m;j++){
			for(int k=l[i];k<=min(j,r[i]);k++)
				dp[i][j]+=dp[i-1][j-k] ;
		}
	}
	cout << dp[n][m] ;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值