文件名称:汽车加油问题详细解析及代码
文件大小:4KB
文件格式:CPP
更新时间:2014-06-27 10:26:08
算法实验报告《贪心算法—汽车加油问题》解析详尽,合适参考。
/*问题描述:一辆汽车加满油后可行驶nkm ,旅途中有若干个加油站,设计一个有效的算法,
* 指出应在哪些加油站停靠加油,使沿途加油次数最少。
*算法设计:对于给定的n和k个加油站位置,计算最少加油次数。
* 数据输入;由文件input.txt给出输入数据。第一行有2个正整数n和k,
* 表示汽车加油后可以行驶的nkm,且旅途中有k个加油站,
* 接下来的一行中有k+1个整数,表示第k个加油站与k-1个加油站之间的距离,
* 第0个加油站表示出发地,汽车已加满油。第k+1个加油站表示目的地,
*结果输出:将计算的最少加油次数输出到文件output.txt
* 如果无法到达目的地则输出”no solution“.
* 输入文件示例: 输出文件示例:
* input.txt output.txt
* 7 7 4
* 1 2 3 4 5 1 6 6
部分代码:
void greedy(int d[],int n,int k) {
int num = 0;
int i=0;
int s=0;
for( i = 0;i < k;i++) {
if(d[i] > n) { //当任意的两个加油站之间的距离大于了汽车的最大行驶距离N
cout<<"no solution\n"<