bzoj1655[Usaco2006 Jan] Dollar Dayz 奶牛商店*

Posted YuanZiming

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj1655[Usaco2006 Jan] Dollar Dayz 奶牛商店*相关的知识,希望对你有一定的参考价值。

bzoj1655[Usaco2006 Jan] Dollar Dayz 奶牛商店

题意:

商场里有K种工具,价格分别为1,2,…,K美元。约翰手里有N美元,必须花完。求购买组合方案。n≤1000,k≤100。

题解:

完全背包,不过要高精度。

代码:

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 #include <queue>
 5 #define inc(i,j,k) for(int i=j;i<=k;i++)
 6 #define maxn 1010
 7 #define ll long long
 8 using namespace std;
 9 
10 inline int read(){
11     char ch=getchar(); int f=1,x=0;
12     while(ch<0||ch>9){if(ch==-)f=-1; ch=getchar();}
13     while(ch>=0&&ch<=9)x=x*10+ch-0,ch=getchar();
14     return f*x;
15 }
16 struct bigint{
17     int len,num[100];
18     void operator = (int a){len=0; memset(num,0,sizeof(num)); while(a)num[++len]=a%10,a/=10;}
19     void operator = (bigint a){
20         memset(num,0,sizeof(num)); inc(i,1,a.len)num[i]=a.num[i]; len=a.len;
21     }
22     void operator += (bigint a){
23         len=max(len,a.len);
24         inc(i,1,len){num[i]+=a.num[i]; if(num[i]>=10)num[i+1]+=num[i]/10,num[i]%=10;}
25         if(num[len+1])len++;
26     }
27     void print(){for(int i=len;i>=1;i--)printf("%d",num[i]);}
28 };
29 int n,k,x,y; bigint f[2][maxn];
30 int main(){
31     n=read(); k=read(); x=0; y=1; f[x][0]=1;
32     inc(i,1,k){
33         inc(j,0,n)f[y][j]=f[x][j]; inc(j,i,n)f[y][j]+=f[y][j-i]; swap(x,y);
34     }
35     f[x][n].print(); return 0;
36 }

 

20160927

以上是关于bzoj1655[Usaco2006 Jan] Dollar Dayz 奶牛商店*的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ 1719--[Usaco2006 Jan] Roping the Field 麦田巨画

BZOJ1654[Usaco2006 Jan]The Cow Prom 奶牛舞会 赤果果的tarjan

BZOJ1718 [Usaco2006 Jan] Redundant Paths 分离的路径

bzoj 1654: [Usaco2006 Jan]The Cow Prom 奶牛舞会tarjan

BZOJ 1656 [Usaco2006 Jan] The Grove 树木:bfs射线法

BZOJ 1718: [Usaco2006 Jan] Redundant Paths 分离的路径