首页 技术 正文
技术 2022年11月9日
0 收藏 936 点赞 1,224 浏览 892 个字

题意:John有N美元,有价格为1~K的工具,可以买的个数不限,问1~K组合出N的方案数。

f[i = 第i中工具][j = 花费为j] = 方案数。

f[i][j] = sigma{ f[i-1][r+k*i] , k ≤ j/i } = f[i][j-i] + f[i-1][j] (优化

这题主要的问题是答案会爆long long。

用两个long long 拼一下就好。

#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<queue>
#include<vector>
#include<stack>
#include<vector>
#include<map>
#include<set>
#include<algorithm>
//#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ll;
const int maxn = 1e3+;const ll carry = 1e18;
struct dll
{
ll a,b;
dll operator + (dll &th){
dll re = {a+th.a,b+th.b};
if(re.b >= carry) {
re.a += re.b / carry;
re.b %= carry;
}
return re;
}
void OUT(){
if(a){
printf("%I64u%I64u\n",a,b);
}else{
printf("%I64u\n",b);
}
}
};dll f[maxn];//f[i][j] = sigma f[i-1][r+k*i] = f[i][j-i] + f[i-1][j]//#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int N,K;
cin>>N>>K;
f[].b = ; f[].a = ;
for(int i = ; i <= K; i++){
for(int r = ; r < i; r++){
for(int j = r+i; j <= N; j += i){
f[j] = f[j-i] + f[j];
}
}
}
f[N].OUT(); return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,488
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,487
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,127
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,289