算法第四章作业

一、           你对贪心算法的理解

 

贪心算法总是做出在当前看来是最好的选择,但不一定是整体的最优,只是在某种意义上的局部最优选择。

二、           请说明汽车加油问题的贪心选择性质

题目来源:王晓东《算法设计与分析》

 

一辆汽车加满油后可行驶 n公里。旅途中有若干个加油站。设计一个有效算法,指出应 在哪些加油站停靠加油,使沿途加油次数最少。

 

输入格式:

第一行有 2 个正整数n和 k(k<=1000 ),表示汽车加满油后可行驶n公里,且旅途中有 k个加油站。 第二行有 k+1 个整数,表示第 k 个加油站与第k-1 个加油站之间的距离。 第 0 个加油站表示出发地,汽车已加满油。 第 k+1 个加油站表示目的地。

 

输出格式:

输出最少加油次数。如果无法到达目的地,则输出“No Solution!”。

 

输入样例:

7 7

1 2 3 4 5 1 6 6

输出样例:

4

 

题目分析:

做法:用逐次删去的策略不够好,用“used”来存放已经使用的油量,

当used大于里程的时候cnt++,这样的策略比较好

 

实现代码:

#include

using namespace std;/*做法:用7逐次删去的策略不够好,用“used”来存放已经使用的油量,

当used大于里程的时候cnt++,这样的策略比较好*/

#define max 10000

int dis[max];

//int cnt = 0; 坑点  全局变量不能随便用  无解时候用cout cnt 会多一个cnt 

int use = 0;

void fun(int n, int k){//n公里 k个加油站

        int cnt  = 0;

        for(int i = 0; i <= k; ++i){

        if(dis[i] > n){

            cout<< "No Solution!";

            return;

            }

        }

        for(int i = 0; i <= k; ++i){

            use += dis[i];

            if(use > n){ // 如果是等于k 说明还是能够到达的

            cnt ++;

            // use = 0; 是错误的 正确做法是cnt++ 令use等于本次里程

            use = dis[i];

        }

    }

    cout << cnt;

    return;

}

int main(){

    int n, k;

    cin >> n >> k;

    for(int i = 0; i <= k; i++){

        cin >> dis[i];

    }

    fun(n,k);

    return 0;

}

 

三、           请说明在本章学习过程中遇到的问题及结对编程的情况

贪心策略不像动态规划那么绕,但它也有它的难点所在,比如不是所有题目都可以用贪心策略来解决的。例如第四章作业题里的货币找零,货币可能会出现“18 = 9 * 2 or 18 = 10 + 5 + 3”这样的情况。所以如何“因地制宜”调整贪心策略则成了我们需要学习的地方。

我和我的小伙伴合作得很融洽,他也一直在带我,我也一直在进步,我们决定期末的大作业做一个刷题小帮手,希望接下来的日子多多加油啦。

 

你可能感兴趣的:(算法第四章作业)