九度OJ #1437 To Fill or Not to Fil
- 题目描写叙述:
-
With highways available, driving a car from Hangzhou to any other city is easy. But since the tank capacity of a car is limited, we have to find gas stations on the way from time to time. Different gas station may give different
price. You are asked to carefully design the cheapest route to go.
- 输入:
-
For each case, the first line contains 4 positive numbers: Cmax (<= 100), the maximum capacity of the tank; D (<=30000), the distance between Hangzhou and the destination city; Davg (<=20), the average distance per unit gas that
the car can run; and N (<= 500), the total number of gas stations. Then N lines follow, each contains a pair of non-negative numbers: Pi, the unit gas price, and Di (<=D), the distance between this station and Hangzhou, for i=1,...N. All the numbers in a line
are separated by a space.
- 输出:
-
For each test case, print the cheapest price in a line, accurate up to 2 decimal places. It is assumed that the tank is empty at the beginning. If it is impossible to reach the destination, print "The maximum travel distance
= X" where X is the maximum possible distance the car can run, accurate up to 2 decimal places.
- 例子输入:
-
50 1300 12 8
6.00 1250
7.00 600
7.00 150
7.10 0
7.20 200
7.50 400
7.30 1000
6.85 300
50 1300 12 2
7.10 0
7.00 600
- 例子输出:
-
749.17
The maximum travel distance = 1200.00
- 来源:
这道题确实挺难的,花了好久的时间,然后自己考虑不全面,最后參考别人的代码才搞定。
就不敢写原创了。。。
http://ziliao1.com/Article/Show/73A96AF77079A6C32C4AA82604FCF691
典型的贪心法。
思想就是考虑下一次在何网站加油(从而决定了在本网站须要加多少油)。
考虑这样几种情况:
1、到达下一网站所需油量 > 油箱最大容量:则下一网站不可达。做法是把油箱加满,尽可能跑,然后break掉。
2、下一网站可达,且油价比本网站廉价:则应尽早“换用”更廉价的油。做法是本站加够就可以。使得刚好能到达下一站。
3、下一网站可达。但油价比本网站贵:此处第一次做错了,不应该在本站把油箱加满,而应该继续寻找满油的条件下可达的下一个比本站廉价的网站。若找到,则加够就可以(所以情况2能够并到这里);若未找到,则在本站将油箱加满。
#include <algorithm> #include <iomanip>
#include <iostream>
using namespace std;
struct station
{
float price;
float dist;
};
station st[501];
float cmax, d, davg;
int n;
bool cmp(station a, station b)
{
return a.dist < b.dist;
}
// 寻找下一个可达的廉价网站
int nextCheaper(int now)
{
for(int i = now; i < n; i++)
{
if(st[i].dist - st[now].dist > cmax * davg) break;
if(st[i].price < st[now].price)
return i;
}
return -1;
}
int main()
{
while(cin >> cmax)
{
cin >> d >> davg >> n;
for(int i = 0; i < n; i++)
cin >> st[i].price >> st[i].dist;
st[n].price = -1; st[n].dist = d;
n = n + 1;
sort(st, st + n, cmp);
int nowst = 0;
float nowgas = 0;
float cost = 0;
while(nowst < n - 1)
{
if(nowst == 0 && st[0].dist != 0)
{
st[nowst].dist = 0; break;
}
float needgas = (st[nowst + 1].dist - st[nowst].dist) / davg;
if(needgas > cmax)
{
float addgas = cmax - nowgas;
cost += addgas * st[nowst].price;
st[nowst].dist += cmax * davg;
break;
}
int nextc = nextCheaper(nowst);
if(nextc == -1)
{
float addgas = cmax - nowgas;
nowgas = cmax;
cost += addgas * st[nowst].price;
nowgas -= needgas;
nowst = nowst + 1;
}else{
needgas = (st[nextc].dist - st[nowst].dist) / davg;
float addgas = needgas - nowgas;
if(addgas > 0)
{
nowgas += addgas;
cost += addgas * st[nowst].price;
}
nowgas -= needgas;
nowst = nextc;
}
}
if(nowst == n - 1)
cout << fixed << setprecision(2) << cost << endl;
else{
float maxdist = st[nowst].dist;
cout << "The maximum travel distance = "<< fixed << setprecision(2) << maxdist << endl;
}
}
return 0;
}以下是我模仿大神自己手写的代码,差点儿都改动的全然一样了。。。眼下还是过不了。郁闷
有时间再研究一下啦。。。如今 真的发现不了什么错误了
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
struct station
{
float pri;
float dis;
}a[999];
int c,d,davg,n;
int cmp(station t1,station t2)
{
return t1.dis<t2.dis;
}
int next(int now)
{
for(int i=now+1;i<=n&&a[i].dis-a[now].dis<=c*davg;i++)
{
if(a[i].pri<a[now].pri)
return i;
}
return -1;
} int main()
{
int i;
while(cin>>c>>d>>davg>>n)
{
for(i=0;i<n;i++)
{
scanf("%f %f",&a[i].pri,&a[i].dis);
}
a[n].pri=-1;
a[n].dis=d;
sort(a,a+n,cmp);
// for(i=0;i<n;i++)
//printf("%f %f\n",a[i].dis,a[i].pri);
int nowst=0;
float anspri=0,ansdis=0,nowgas=0;
while(nowst<n)
{
if(nowst==0&&a[0].dis!=0)
{
ansdis=0;
break;
}
float needgas=(a[nowst+1].dis-a[nowst].dis)/davg;
if(needgas>c)
{
ansdis+=davg*c;
break;
}
int nextst=next(nowst);
// printf("%d %d %f\n",nowst,nextst,anspri);
if(nextst==-1)
{
anspri+=(c-nowgas)*a[nowst].pri;
nowgas=c-needgas;
ansdis=a[nowst+1].dis;
nowst+=1; }
else
{
float addgas=(a[nextst].dis-a[nowst].dis)/davg-nowgas;
if(addgas>0)
{
nowgas=0;
anspri+=addgas*a[nowst].pri;
}
else
nowgas-=needgas; nowst=nextst;
ansdis=a[nowst].dis; }
}
if(nowst==n)
printf("%.2f\n",anspri);
else
printf("The maximum travel distance = %.2f\n",ansdis);
}
return 0;
} /**************************************************************
Problem: 1437
User: HCA1101
Language: C++
Result: Wrong Answer
****************************************************************/
九度OJ #1437 To Fill or Not to Fil的更多相关文章
- 九度oj 1437 To Fill or Not to Fill 2012年浙江大学计算机及软件工程研究生机试真题
题目1437:To Fill or Not to Fill 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:1488 解决:345 题目描述: With highways availabl ...
- 九度OJ 1437 To Fill or Not to Fill -- 贪心算法
题目地址:http://ac.jobdu.com/problem.php?pid=1437 题目描述: With highways available, driving a car from Hang ...
- 九度OJ 1437 To Fill or Not to Fill
题目大意:小明从杭州去往某目的地,要经过一些加油站,每个加油站的价格不一样.若能顺利到达,求加油费用最少为多少,否则求出能行驶的最远距离. 思路:贪心算法 1>若下一加油站的价格更便宜,则只需走 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ 1502 最大值最小化(JAVA)
题目1502:最大值最小化(二分答案) 九度OJ Java import java.util.Scanner; public class Main { public static int max(in ...
- 九度OJ,题目1089:数字反转
题目描述: 12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转. 输入: 第一行一个正整数表示测试数据的个数n. ...
- 九度OJ 1500 出操队形 -- 动态规划(最长上升子序列)
题目地址:http://ac.jobdu.com/problem.php?pid=1500 题目描述: 在读高中的时候,每天早上学校都要组织全校的师生进行跑步来锻炼身体,每当出操令吹响时,大家就开始往 ...
- 九度OJ 1531 货币面值(网易游戏2013年校园招聘笔试题) -- 动态规划
题目地址:http://ac.jobdu.com/problem.php?pid=1531 题目描述: 小虎是游戏中的一个国王,在他管理的国家中发行了很多不同面额的纸币,用这些纸币进行任意的组合可以在 ...
- 九度OJ 1024 畅通工程 -- 并查集、贪心算法(最小生成树)
题目地址:http://ac.jobdu.com/problem.php?pid=1024 题目描述: 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但 ...
随机推荐
- strcpy与strcat函数原型
1.strcpy函数原型 char *my_strcpy(char *dest,const char *src) //const使在函数中不能修改*src其原先的值{ char *strDest ...
- Spring核心技术(十二)——基于Java的容器配置(二)
使用@Configuration注解 @Configuration注解是一个类级别的注解,表明该对象是用来指定Bean的定义的.@Configuration注解的类通过@Bean注解的方法来声明Bea ...
- debian 9 安装AMD驱动
目录 debian 9 安装AMD驱动 安装驱动之前: 安装驱动: 安装驱动之后: debian 9 安装AMD驱动 需求说明: 安装完成debian系统后独显驱动未安装 操作系统版本: kyeup@ ...
- 更新yum源导致yum不可用
当安装和yum配置相关的包后报yum模块找不到 yum install -y yum-utils device-mapper-persistent-data lvm2 yum list|grep yu ...
- 08-为数组和arguments
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- GFS, HDFS, Blob File System架构对比
分布式文件系统很多,包括GFS,HDFS,淘宝开源的TFS,Tencent用于相册存储的TFS (Tencent FS,为了便于区别,后续称为QFS),以及Facebook Haystack.其中,T ...
- oracle查询正在执行的语句以及正被锁的对象
--查询Oracle正在执行的sql语句及执行该语句的用户 b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, paddr, ...
- Bichrome Tree
Bichrome Tree 时间限制: 1 Sec 内存限制: 128 MB 题目描述 We have a tree with N vertices. Vertex 1 is the root of ...
- EC++学习笔记(六) 继承和面向对象设计
条款32:确定你的 public 继承塑模出 is-a 关系 public inheritance 意味着 is-a 关系class Derived 以 public 形式继承 class Base, ...
- Codevs 1021 玛丽卡==洛谷 P1186
时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 麦克找了个新女朋友,玛丽卡对他非常恼火并伺机报复. 因为她和他们不住在同一个 ...