Tyche 2147 旅行
题目描述
你有m元钱,将要游览n个国家。每一个国家有一种商品,其中第i个国家商品的单价为ai元。每到一个国家,你会用手上的钱疯狂购买这个国家的商品,直到剩余的钱无法购买为止。
现在你要决定游览这n个国家的顺序,使得游览完n个国家后剩余的钱最多。
输入包含两行。
第一行两个整数n和m,表示国家数和钱数。
第二行n个整数分别为每个国家商品的单价。
一行一个整数,表示最多剩余多少元钱。
3 31
5 7 11
4
1≤n≤1000,1≤m≤5000,1≤ai≤1000000000
解题思路
第一遍看题以为是贪心,只想到了排序,但是不知道该如何最优。
考试结束之后得知正解是dp后,我慌了。(其实看数据范围明显是dp
考虑dp[i][j]表示m取模前i个数得到j是否可行,有两种转移。
1 a[i]不选dp[i][j]|=dp[i-1][j]
2 a[i]选 dp[i][j%a[i]]|=dp[i-1][j]
初态dp[0][m]=dp[0][0]=1
终态在所有dp[n][j]==1中选最大的j%a[n]
dp是学不会的,这辈子都不可能。
#include<algorithm>
#include<iostream>
#include<cstdio>
using namespace std;
const int N=;
int n,m,ans,f[N][*N],a[N];//f[i][j]表示m取模前i个数得到j是否可行
bool cmp(int c,int d)
{
return c>d;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
scanf("%d",a+i);
sort(a+,a+n+,cmp);
f[][m]=,f[][]=;
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
{
f[i][j]=f[i-][j];
f[i][j%a[i]]|=f[i-][j];
}
for(int i=;i<=m;i++)
if(f[n][i])
ans=max(ans,i%a[n]);
printf("%d\n",ans);
return ;
}
Tyche 2147 旅行的更多相关文章
- BZOJ 3531: [Sdoi2014]旅行 [树链剖分]
		3531: [Sdoi2014]旅行 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1685 Solved: 751[Submit][Status] ... 
- vijos P1780 【NOIP2012】 开车旅行
		描述 小\(A\)和小\(B\)决定利用假期外出旅行,他们将想去的城市从\(1\)到\(N\)编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市\(i\)的海拔高度为 ... 
- codev 2147 数星星
		2147 数星星 http://codevs.cn/problem/2147/ 题目描述 Description 小明是一名天文爱好者,他喜欢晚上看星星.这天,他从淘宝上买下来了一个高级望远镜.他十分 ... 
- 【BZOJ-1570】BlueMary的旅行     分层建图 + 最大流
		1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 388 Solved: 212[Submit ... 
- codevs 1036 商务旅行(Targin求LCA)
		传送门 Description 某首都城市的商人要经常到各城镇去做生意,他们按自己的路线去做,目的是为了更好的节约时间. 假设有N个城镇,首都编号为1,商人从首都出发,其他各城镇之间都有道路连接,任意 ... 
- nyoj 71 独木舟上的旅行(贪心专题)
		独木舟上的旅行 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客 ... 
- 【bzoj3531】 [SDOI2014]旅行
		题目描述 S国有N个城市,编号从1到N.城市间用N-1条双向道路连接,满足从一个城市出发可以到达其它所有城市.每个城市信仰不同的宗教,如飞天面条神教.隐形独角兽教.绝地教都是常见的信仰.为了方便,我们 ... 
- tomcat源码分析(三)一次http请求的旅行-从Socket说起
		p { margin-bottom: 0.25cm; line-height: 120% } tomcat源码分析(三)一次http请求的旅行 在http请求旅行之前,我们先来准备下我们所需要的工具. ... 
- 11.14 T2 小x的旅行(小x的旅行)
		1.小x的旅行 (travel.pas/c/cpp) [问题描述] 小x大学毕业后,进入了某个公司做了高层管理,他每年的任务就是检查这个公司在全国各地N个分公司的各种状况,每个公司都要检查一遍,且 ... 
随机推荐
- Python爬虫  获得淘宝商品评论
			自从写了第一个sina爬虫,便一发不可收拾.进入淘宝评论爬虫正题: 在做这个的时候,也没有深思到底爬取商品评论有什么用,后来,爬下来了数据.觉得这些数据可以用于帮助分析商品的评论,从而为用户选择商品提 ... 
- kafka模型理解
			1.消息发送至一个topic,而这个topic可以由多个partition组成,每条消息在partition中的位置称为offset 2.消息存在有效期,如果设置为2天,则消息2天后会被删除 3.每个 ... 
- ML.NET 示例:推荐之场感知分解机
			写在前面 准备近期将微软的machinelearning-samples翻译成中文,水平有限,如有错漏,请大家多多指正. 如果有朋友对此感兴趣,可以加入我:https://github.com/fei ... 
- .NET-记一次架构优化实战与方案-前端优化
			目录 .NET-记一次架构优化实战与方案-梳理篇 .NET-记一次架构优化实战与方案-前端优化 .NET-记一次架构优化实战与方案-底层服务优化 前言 上一篇<.NET-记一次架构优化实战与方案 ... 
- 一起学习造轮子(二):从零开始写一个Redux
			本文是一起学习造轮子系列的第二篇,本篇我们将从零开始写一个小巧完整的Redux,本系列文章将会选取一些前端比较经典的轮子进行源码分析,并且从零开始逐步实现,本系列将会学习Promises/A+,Red ... 
- 一文看懂Transformer内部原理(含PyTorch实现)
			Transformer注解及PyTorch实现 原文:http://nlp.seas.harvard.edu/2018/04/03/attention.html 作者:Alexander Rush 转 ... 
- Faster R-CNN:详解目标检测的实现过程
			本文详细解释了 Faster R-CNN 的网络架构和工作流,一步步带领读者理解目标检测的工作原理,作者本人也提供了 Luminoth 实现,供大家参考. Luminoth 实现:https:// ... 
- 【转载】KETTLE集群搭建
			一.集群的原理与优缺点 1.1集群的原理 Kettle集群是由一个主carte服务器和多个从carte服务器组成的,类似于master-slave结构,不同的是’master’处理具体任务,只负责任务 ... 
- H5 69-清除浮动方式四
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- H5 40-CSS精灵图
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
