【t040】SETI任务
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
Sqybi的电脑在做一个任务,就是SETI@home,据说这个任务在全世界有500 多万台电脑在同时做,可以说是最热门的。它的目的
就是通过分析射电望远镜收到的无线电信号查找外太空智慧生物。这个任务算是起步比较早的,它也会为我们分配很多的任务。
这样,我们的机器有的时候就不能在给定的期限内完成所有的任务。现在sqybi 就遇到了这个问题,由于他的电脑是笔记本,他
不能用太多的时间运行所有的任务。他希望你能够提供一个程序,用来告诉他应该运行哪些任务以使他得到的积分最多。注意一
下,一个单位时间内只能运行一个任务,而每个任务都有一个固定的积分。如果没有完成一项任务,那么在这项任务上不会得到
任何的积分。 现在提供每个任务需要的单位时间和可以得到的积分以及sqybi 可以用来运行任务的总时间,需要输出sqybi 可以得到的最大积分。
【输入格式】
第1 行是一个正整数n 和一个正整数m,分别代表被分配的任务数和总共可以用来运行任务的时间,中间用一个空格分开。
第2 行到第n+1 行每行两个数,用空格分开,分别是正整数t 和正实数p。t 表示该任务需要的时间,p表示该任务可以得到的积分数。
【数据范围】
对于30%数据,n≤15。
对于100%数据,p 的小数位不会超过三位,p≤100,m≤10000,n≤1000。
【输出格式】
仅一行,表示sqybi 可以得到的最大积分,保留三位小数。
Sample Input
4 10
5 1
1 5
6 10
4 6
Sample Output
16.000
【题解】
这就是一个0/1背包问题。然后因为价值是实数,所以用double类型的f数组来存最优值。更新的时候记得逆序更新就好。没有坑点。最后“%.3lf”输出。
ps:不想强迫自己写模块化的代码了。从这篇后可能就是直接写下来了。
【代码】
#include <cstdio> int n,m,w[1010];
double c[1010],f[10010]; void input_data()
{
scanf("%d%d",&n,&m);
for (int i = 1;i <= n;i++) //输入花费和获得的价值
scanf("%d%lf",&w[i],&c[i]);
} void get_ans()
{
for (int i = 1;i <= n;i++)
for (int j = m;j >= w[i];j--) //因为是0/1背包所以逆序更新。这样不会影响到其他要更新的位置
if (f[j] <f[j-w[i]] + c[i])
f[j] = f[j-w[i]] + c[i];
} void output_ans()
{
printf("%.3lf",f[m]); //保留3位小数输出。
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
input_data();
get_ans();
output_ans();
return 0;
}
【t040】SETI任务的更多相关文章
- ACdream 1430——SETI——————【后缀数组,不重叠重复子串个数】
SETI Time Limit: 4000/2000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) Submit Statist ...
- UVA 1563 - SETI (高斯消元+逆元)
UVA 1563 - SETI option=com_onlinejudge&Itemid=8&page=show_problem&category=520&probl ...
- POJ_2065 SETI 【同余高斯消元】
一.题目 SETI 二.分析 给定一个模数,一串字符串,字符串长度为N,相当于是N个方程的答案,而这N个方程中有N个未知数,要求的就是这N个未知数的值,很显然的高斯消元,遇到模数和除法,用逆元就好. ...
- 【poj2065】 SETI
http://poj.org/problem?id=2065 (题目链接) 题意 题意半天看不懂..给你一个素数P(P<=30000)和一串长为n的字符串str[].字母'*'代表0,字母a-z ...
- POJ2065 SETI(高斯消元 同模方程)
(a1 * 1^0 + a2 * 1^1 + ... an * 1^n - 1) % P = f1 .... (a1 * n^0 + a2 * n^1 + ... an - 1 * ...
- [ACDream 1430]SETI 后缀数组
题目链接:http://acdream.info/problem?pid=1430 题目大意:给你一个长度不超过10000的字符串,问你出现过两次或两次以上的不重叠的子串有多少个. 后缀数组计算出he ...
- POJ 2065 SETI(高斯消元)
题目链接:http://poj.org/problem?id=2065 题意:给出一个字符串S[1,n],字母a-z代表1到26,*代表0.我们用数组C[i]表示S[i]经过该变换得到的数字.给出一个 ...
- POJ 2065 SETI (高斯消元 取模)
题目链接 题意: 输入一个素数p和一个字符串s(只包含小写字母和‘*’),字符串中每个字符对应一个数字,'*'对应0,‘a’对应1,‘b’对应2.... 例如str[] = "abc&quo ...
- poj 2065 SETI 高斯消元
看题就知道要使用高斯消元求解! 代码如下: #include<iostream> #include<algorithm> #include<iomanip> #in ...
随机推荐
- springMVC视图解析器——InternalResourceViewResolver(转)
springmvc在处理器方法中通常返回的是逻辑视图,如何定位到真正的页面,就需要通过视图解析器. springmvc里提供了多个视图解析器,InternalResourceViewResolver就 ...
- 网络博客 VC\图案像处理
http://blog.csdn.net/lvwx369/article/category/1185452 http://blog.csdn.net/lyy289065406/article/deta ...
- 各大免费邮箱邮件群发账户SMTP服务器配置及SMTP发送量限制情况
网络产品推广和新闻消息推送时,经常用到的工具就是用客户邮箱发送邮件了,如果是要发送的邮件量非常大的话,一般的建议是搭建自己的邮局服务器,或者是花钱购买专业的邮件群发服务,免费邮箱的SMTP适合少量的邮 ...
- JVM route
http://www.linuxidc.com/Linux/2013-06/86446.htm
- Dcloud课程2 什么是Dcloud
Dcloud课程2 什么是Dcloud 一.总结 一句话总结:DCloud提供了一套快速开发应用的跨平台技术方案. 1.DCloud的产品架构? MUI+(H5+)+HBuilder 2.什么是MU ...
- 微服务实践(五):微服务的事件驱动数据管理 - DockOne.io
原文:微服务实践(五):微服务的事件驱动数据管理 - DockOne.io [编者的话]本文是使用微服务创建应用系列的第五篇文章.第一篇文章介绍了微服务架构模式,并且讨论了使用微服务的优缺点:第二和第 ...
- 【Codeforces Round #433 (Div. 1) B】Jury Meeting
[链接]h在这里写链接 [题意] 有n个人,它们都要在某一时刻开始,全都到达0位置,然后维持最少k个时间单位,然后再全都回到原来的位置; 第i个人初始的位置是i. 且一共有m班航班. 每一班航班,要么 ...
- [D3] Create Chart Axes with D3 v4
Most charts aren’t complete without axes to provide context and labeling for the graphical elements ...
- 缓存(cache)的理解
缓存的特点: 读取速度很快,容量相比硬盘较小: 缓存在实现时,本质上仍然是一块内存区域: cache 机制的一个核心关注点还在于,究竟什么样的数据应该放在缓存中,显然不是所有,那就应当是部分,就应该是 ...
- linux 内核源代码目录结构
/arch:目录包括了所有和体系结构相关的核心代码.它下面的每一个子目录都代表一种Linux支持的体系结构,例如i386就是Intel CPU及与之相兼容体系结构的子目录.PC机一般都基于此目录. / ...