题目描写叙述:

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
来源:

2012年浙江大学计算机及软件project研究生机试真题

这道题确实挺难的,花了好久的时间,然后自己考虑不全面,最后參考别人的代码才搞定。

就不敢写原创了。。。



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的更多相关文章

  1. 九度oj 1437 To Fill or Not to Fill 2012年浙江大学计算机及软件工程研究生机试真题

    题目1437:To Fill or Not to Fill 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:1488 解决:345 题目描述: With highways availabl ...

  2. 九度OJ 1437 To Fill or Not to Fill -- 贪心算法

    题目地址:http://ac.jobdu.com/problem.php?pid=1437 题目描述: With highways available, driving a car from Hang ...

  3. 九度OJ 1437 To Fill or Not to Fill

    题目大意:小明从杭州去往某目的地,要经过一些加油站,每个加油站的价格不一样.若能顺利到达,求加油费用最少为多少,否则求出能行驶的最远距离. 思路:贪心算法 1>若下一加油站的价格更便宜,则只需走 ...

  4. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  5. 九度OJ 1502 最大值最小化(JAVA)

    题目1502:最大值最小化(二分答案) 九度OJ Java import java.util.Scanner; public class Main { public static int max(in ...

  6. 九度OJ,题目1089:数字反转

    题目描述: 12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转. 输入: 第一行一个正整数表示测试数据的个数n. ...

  7. 九度OJ 1500 出操队形 -- 动态规划(最长上升子序列)

    题目地址:http://ac.jobdu.com/problem.php?pid=1500 题目描述: 在读高中的时候,每天早上学校都要组织全校的师生进行跑步来锻炼身体,每当出操令吹响时,大家就开始往 ...

  8. 九度OJ 1531 货币面值(网易游戏2013年校园招聘笔试题) -- 动态规划

    题目地址:http://ac.jobdu.com/problem.php?pid=1531 题目描述: 小虎是游戏中的一个国王,在他管理的国家中发行了很多不同面额的纸币,用这些纸币进行任意的组合可以在 ...

  9. 九度OJ 1024 畅通工程 -- 并查集、贪心算法(最小生成树)

    题目地址:http://ac.jobdu.com/problem.php?pid=1024 题目描述:     省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但 ...

随机推荐

  1. SpringBoot 多线程

    Spring通过任务执行器(TaskExecutor)来实现多线程和并发编程.使用ThreadPoolTaskExecutor可实现一个基于线程池的TaskExecutor.而实际开发中任务一般是非阻 ...

  2. [转]Makefile中的wildcard/notdir/patsubst

    1.wildcard : 扩展通配符 2.notdir : 去除路径 3.patsubst :替换通配符 例子:建立一个测试目录,在测试目录下建立一个名为sub的子目录$ mkdir test$ cd ...

  3. docker+Battery Historian 环境搭建(电量分析)

    docker 安装(windows) 1.  下载 https://docs.docker.com/docker-for-windows/install/  和 安装和添加环境变量(...) 2. 安 ...

  4. Clojure基础

    最近看了一段clojure,下面是从书上摘下来的一下语言基础的精华部分 ;函数的基本形式 (defn average [numbers] (/ (apply + numbers) (count num ...

  5. tab栏切换效 简易效果

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  6. 【Luogu】P2831愤怒的小鸟(手算抛物线+状压DP)

    题目链接 设f[s]表示二进制集合表示下的s集合都打掉用了多少小鸟. 预处理出lne[i][j]表示i.j确定的抛物线能打掉的小鸟集合. 于是就有f[s|lne[i][j]]=min(f[s|lne[ ...

  7. P3146 [USACO16OPEN]248 (区间DP)

    题目描述  给定一个1*n的地图,在里面玩2048,每次可以合并相邻两个(数值范围1-40),问最大能合出多少.注意合并后的数值并非加倍而是+1,例如2与2合并后的数值为3. 这道题的思路: 状态: ...

  8. Sql Server 中的 @@ERROR

    @@ERROR:当前一个语句遇到错误,则返回错误号,否则返回0.需要注意的是@ERROR在每一条语句执行后会被立刻重置,因此应该在要验证的语句执行后检查数值或者是将它保存到局部变量中以备将来使用. D ...

  9. Fruit Ninja

    Fruit Ninja 时间限制:C/C++ 5秒,其他语言10秒 空间限制:C/C++ 262144K,其他语言524288K 64bit IO Format: %lld 题目描述 Fruit Ni ...

  10. 送外卖(codevs 2800)

    题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n个不同的客户的手上.n个不同的客户分别在1~n个编号的城市中.送外卖的从0号城市出发,然后n个城市都要走一 ...