NOIP2017模拟赛 senior 6.29 T3 Gift(gift)

2024-02-13 14:40
文章标签 模拟 t3 noip2017 gift senior 6.29

本文主要是介绍NOIP2017模拟赛 senior 6.29 T3 Gift(gift),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NOIP2017模拟赛 senior 6.29 T3 Gift(gift)

Description

Input

Output

 

这道题的难度相对来说并没有第二题恼火,但还是很难搞的。

那么这道题读完题目还是比较好看出这是一道背包的变形题。

因为每一份礼物都是取或者不取两个状态,所以,01背包好理解吧。

然后题目中说选到不能选为止,所以我们先将读入的礼物的价值排个序,然后从大到小我们去选取礼物,如果当前礼物价值大于剩余财富,那么我们就不能选了对吧。

于是就这样一层层的向下进行动归。

每一次我们处理当前层的DP数组,将答案加上上一层DP数组的值。这样我们就合理的处理完了整个DP数组。

所以说,这道题目的主要思想还是01背包,但是其中还加上了我们根据题意所得的排序预处理。

 

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<algorithm>
 5 #include<cmath>
 6 #define INT_MAX_ 0x7fffffff
 7 #define LONG_MAX_ 0x7fffffffffffffffll
 8 #define pi acos(-1)
 9 #define N 1010
10 #define mod 10000007
11 using namespace std;
12 
13 inline int read()
14 {
15     int data=0,w=1;
16     char ch=0;
17     while(ch!='-' && (ch<'0' || ch>'9')) ch=getchar();
18     if(ch=='-') w=-1,ch=getchar();
19     while(ch>='0' && ch<='9') data=data*10+ch-'0',ch=getchar();
20     return data*w;
21 }
22 
23 inline void write(int x)
24 {
25     if(x<0) putchar('-'),x=-x;
26     if(x>9) write(x/10);
27     putchar(x%10+'0');
28 }
29 
30 int n,m;
31 int Val[N],Sum[N],dp[N][N],ans;
32 
33 int main()
34 {
35     freopen("gift.in","r",stdin);
36     freopen("gift.out","w",stdout);
37     
38     n = read();
39     m = read();
40     for(int i = 1; i <= n; i++)
41     {
42         Val[i] = read();
43     }
44     sort(Val+1,Val+1+n);
45     for(int i = 1; i <= n; i++)
46     {
47         Sum[i] = Sum[i-1] + Val[i];
48     }
49     dp[n+1][m] = 1;
50     for(int i = n; i >= 1; i--)
51     {
52         for(int j = Sum[i-1]; j < min(m + 1, Val[i] + Sum[i-1]); j++)
53         {
54             ans = (ans + dp[i+1][j]) % mod;
55         }
56         for(int j = m; j >= 0; j--)
57         {
58             if(j + Val[i] <= m) dp[i][j] = dp[i+1][j+Val[i]];
59             dp[i][j] = (dp[i][j] + dp[i+1][j]) % mod;
60         }
61     }
62     if(ans == 0) ans = 1;
63     write(ans);
64     
65     return 0;
66 }

 

转载于:https://www.cnblogs.com/sin-mo/p/7230937.html

这篇关于NOIP2017模拟赛 senior 6.29 T3 Gift(gift)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/705797

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

hdu4431麻将模拟

给13张牌。问增加哪些牌可以胡牌。 胡牌有以下几种情况: 1、一个对子 + 4组 3个相同的牌或者顺子。 2、7个不同的对子。 3、13幺 贪心的思想: 对于某张牌>=3个,先减去3个相同,再组合顺子。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOExcepti

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

【算法专场】模拟(下)

目录 前言 38. 外观数列 算法分析 算法思路 算法代码 1419. 数青蛙 算法分析 算法思路 算法代码  2671. 频率跟踪器 算法分析 算法思路 算法代码 前言 在前面我们已经讲解了什么是模拟算法,这篇主要是讲解在leetcode上遇到的一些模拟题目~ 38. 外观数列 算法分析 这道题其实就是要将连续且相同的字符替换成字符重复的次数+

模拟实现vector中的常见接口

insert void insert(iterator pos, const T& x){if (_finish == _endofstorage){int n = pos - _start;size_t newcapacity = capacity() == 0 ? 2 : capacity() * 2;reserve(newcapacity);pos = _start + n;//防止迭代

PHP实现二叉树遍历(非递归方式,栈模拟实现)

二叉树定义是这样的:一棵非空的二叉树由根结点及左、右子树这三个基本部分组成,根据节点的访问位置不同有三种遍历方式: ① NLR:前序遍历(PreorderTraversal亦称(先序遍历)) ——访问结点的操作发生在遍历其左右子树之前。 ② LNR:中序遍历(InorderTraversal) ——访问结点的操作发生在遍历其左右子树之中(间)。 ③ LRN:后序遍历(PostorderT

1 模拟——67. 二进制求和

1 模拟 67. 二进制求和 给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 示例 1:输入:a = "11", b = "1"输出:"100"示例 2:输入:a = "1010", b = "1011"输出:"10101" 算法设计 可以从低位到高位(从后向前)计算,用一个变量carry记录进位,如果有字符没处理完或者有进位,则循环处理。两个字符串对

AMAZING AUCTION(简单模拟)

AMAZING AUCTION 时间限制: 3000 ms  |  内存限制: 65535 KB 难度:4 描述 Recently the auction house hasintroduced a new type of auction, the lowest price auction. In this new system,people compete for the lo