贪心算法-加油站
一輛汽車加滿油后可行駛n公里。旅途中有若干個加油站。設(shè)計一個有效算法,指出應(yīng)在哪些加油站停靠加油,使沿途加油次數(shù)最少。對于給定的n(n <= 5000)和k(k <= 1000)個加油站位置,編程計算最少加油次數(shù)。并證明算法能產(chǎn)生一個最優(yōu)解。
要求:
輸入:第一行有2個正整數(shù)n和k,表示汽車加滿油后可行駛n公里,且旅途中有k個加油站。接下來的1 行中,有k+1 個整數(shù),表示第k個加油站與第k-1 個加油站之間的距離。第0 個加油站表示出發(fā)地,汽車已加滿油。第k+1 個加油站表示目的地。
輸出:輸出編程計算出的最少加油次數(shù)。如果無法到達(dá)目的地,則輸出”NoSolution”。
思路:
汽車行駛過程中,應(yīng)走到自己能走到并且離自己最遠(yuǎn)的那個加油站,在那個加油站加油后再按照同樣的方法貪心
具體算法:
先檢測各加油站之間的距離,若發(fā)現(xiàn)其中有一個距離大于汽車加滿油能跑的距離,則輸出no solution。否則,對加油站間的距離進(jìn)行逐個掃描,盡量選擇往遠(yuǎn)處走,不能走了就讓num++,最終統(tǒng)計出來的num便是最少的加油站數(shù)
總結(jié)
- 上一篇: 富格林金业:原油天然气怎么掌控买卖点?
- 下一篇: 黄金价格走势软件下载,国内十大现货黄金正