2015安徽省赛 F.多重部分和问题

题目描述

有n种不同大小的数字,每种各个。判断是否可以从这些数字之中选出若干使它们的和恰好为K。

输入

首先是一个正整数T(1<=T<=100) 接下来是T组数据 每组数据第一行是一个正整数n(1<=n<=100),表示有n种不同大小的数字 第二行是n个不同大小的正整数ai(1<=ai<=100000) 第三行是n个正整数mi(1<=mi<=100000),表示每种数字有mi个 第四行是一个正整数K(1<=K<=100000)

输出

对于每组数据,如果能从这些数字中选出若干使它们的和恰好为K,则输出“Yes”,否则输出“No”,每个输出单独占一行

样例输入

2

3

3 5 8 3 2 2

17

2

1 2 1 1

4

样例输出

Yes

No

dp数组

 1 #include <iostream>
 2 #include <stdio.h>
 3 #include <string.h>
 4 using namespace std;
 5 int dp[100001],a[100001],m[100001];
 6 int n,k,T;
 7 int dper()
 8 {
 9     memset(dp,-1,sizeof(dp));
10     dp[0]=0;
11     for(int i=0;i<n;i++)
12     {
13         for(int j=0;j<=k;j++)
14         {
15             if(dp[j]>=0)
16             {
17                 dp[j]=m[i];
18             }
19             else if(j<a[i]||dp[j-a[i]]<=0)
20             {
21                 dp[j]=-1;
22             }
23             else
24             {
25                 dp[j]=dp[j-a[i]]-1;
26             }
27         }
28     }
29     if(dp[k]>=0){printf("Yes\n");}
30     else printf("No\n");
31     return 0;
32 }
33 int main()
34 {
35     scanf("%d",&T);
36     while(T>=1)
37     {
38         scanf("%d",&n);
39         for(int i=0;i<n;i++)
40         {
41             scanf("%d",&a[i]);
42         }
43         for(int i=0;i<n;i++)
44         {
45             scanf("%d",&m[i]);
46         }
47         scanf("%d",&k);
48         dper();
49         T--;
50         n=0;k=0;
51         memset(a,0,sizeof(a));
52         memset(m,0,sizeof(m));
53     }
54     return 0;
55 }
56 /**************************************************************
57     Problem: 1210
58     User: 2014217052
59     Language: C++
60     Result: 正确
61     Time:128 ms
62     Memory:2676 kb
63 ****************************************************************/
64  
时间: 2024-10-27 15:59:44

2015安徽省赛 F.多重部分和问题的相关文章

2015安徽省赛 B.求和

题目描述 对于正整数n,k,我们定义这样一个函数f,它满足如下规律 现在给出n和k,你的任务就是要计算f(n,k)的值. 输入 首先是一个整数T,表示有T组数据 接下来每组数据是n和k(1<=n,k<=108) 输出 打印出f(n,k)的值,每个输出单独占一行 样例输入 3 1 1 2 1 3 1 样例输出 -1 1 -2 找到规律即可. 1 #include <iostream> 2 #include <stdio.h> 3 int main() 4 { 5 usin

2015安徽省赛 H.数7

http://xcacm.hfut.edu.cn/problem.php?id=1212 模拟大发 #include<iostream> #include<cstdio> #include<cstring> #include<cmath> using namespace std; bool judge_prime(int k) { int i; int u=int(sqrt(k*1.0)); for(i=2;i<=u;i++) { if(k%i==0)

2015安徽省赛 I.梯田

http://xcacm.hfut.edu.cn/problem.php?id=1213 set + 搜索 姐姐是用搜索+二分做的,效率要高很多 #include<iostream> #include<cstdio> #include<cstring> #include<set> using namespace std; int x[]={ 0, 0,-1, 1}; int y[]={ 1,-1, 0, 0}; int lable[105][105],d[1

2015安徽省赛 G.你来擒孟获

http://xcacm.hfut.edu.cn/problem.php?id=1211 SPFA模板题目 最短路变种,从起点终点各找一次最短路相加 #include<iostream> #include<vector> #include<deque> #include<cstdio> #include<cstring> using namespace std; struct Edge { int to,length; }; bool spfa(

2015安徽省赛 C.LU的困惑

题目描述 Master LU 非常喜欢数学,现在有个问题:在二维空间上一共有n个点,LU每连接两个点,就会确定一条直线,对应有一个斜率.现在LU把平面内所有点中任意两点连线,得到的斜率放入一个集合中(若斜率不存在则不计入集合),他想知道这个集合中有多少个元素. 输入 第一行是一个整数T,代表T组测试数据 每组数据第一行是一个整数n,代表点的数量.2<n<1000 接下来n行,每行两个整数,0<x<10000,0<y<10000,代表点的坐标 输出 输出斜率集合中有多少个

2015安徽省赛 A.First Blood

题目描述 盖伦是个小学一年级的学生,在一次数学课的时候,老师给他们出了一个难题: 老师给了一个正整数 n,需要在不大于n的范围内选择三个正整数(可以是相同的),使它们三个的最小公倍数尽可能的大.盖伦很想第一个解决这个问题,你能帮助盖伦拿到“first blood”吗? 输入 首先是一个正整数T,表示有T组测试数据 每组测试数据是一个正整数n(1<=n<=10^6) 输出 对于每组测试数据,输出最大的最小公倍数,每个输出单独占一行 样例输入 2 9 7 样例输出 504 210 第一次写的版本相

14年省赛---多重部分和问题(多重背包+二进制优化)

1210: F.多重部分和问题 时间限制: 1 Sec  内存限制: 64 MB提交: 18  解决: 14 题目描述 有n种不同大小的数字,每种各个.判断是否可以从这些数字之中选出若干使它们的和恰好为K. 输入 首先是一个正整数T(1<=T<=100)接下来是T组数据 每组数据第一行是一个正整数n(1<=n<=100),表示有n种不同大小的数字 第二行是n个不同大小的正整数ai(1<=ai<=100000)第三行是n个正整数mi(1<=mi<=100000

2015省赛总结

2015省赛总结 AC-team  周凯——————2015年5月15日----23:35 2015年的省赛已经过去一个星期,今天我就做一下总结. 上周五,我们接到消息,可以作为旅游对去参加今年的省赛,其实听到这个消息我很高兴,因为终于可以出去见识一下什么是真正的ACM竞赛. 就在周四,舍友突发阑尾炎,我和另一基友几乎一晚没睡,舍友更不用说,整整疼了一天一夜.第二天(星期五)中午打的回来时,居然在出租车上睡着了.回来之后,下午接到消息,我们队可以以旅游队的名义去参加省赛,队友得知消息后,都很高兴

编程算法 - 多重部分和问题 代码(C)

多重部分和问题 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 有n种不同大小的数字a, 每种各m个. 判断是否可以从这些数字之中选出若干使它们的和恰好为K. 使用动态规划求解(DP), 方法1: dp[i+1][j] = 用前n种数字是否能加和成j, 时间复杂度O(nKm), 不是最优. 方法2: dp[i+1][j] = 用前i种数加和得到j时, 第i种数最多能剩余多少个. 时间复杂度O(nK). 例如: n=3, a={3,5,8},