博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实验三 贪心算法 汽车加油问题
阅读量:6316 次
发布时间:2019-06-22

本文共 987 字,大约阅读时间需要 3 分钟。

 提高题二: 汽车加油问题

 

一、实验目的与要求

1、掌握汽车加油问题的算法;

2、进一步掌握贪心算法;

二、实验题

     一辆汽车加满油后可以行驶N千米。旅途中有若干个加油站。若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油。并证明你的算法能产生一个最优解。

三、实验提示

把两加油站的距离放在数组中,a[1..n]表示从起始位置开始跑,经过n个加油站,a[k]表示第k1个加油站到第k个加油站的距离。汽车在运行的过程中如果能跑到下一个站则不加油,否则要加油。

 

三、源代码

 

 
  1. import java.util.*; 
  2.  
  3. import java.io.*; 
  4.  
  5.   
  6.  
  7.   
  8.  
  9. public class SF_QicheJiayouzhan 
  10.  
  11.  
  12.        public static int greedy(int x[],int n){ 
  13.  
  14.               int sum=0
  15.  
  16.                      k=x.length, 
  17.  
  18.                      s=0
  19.  
  20.               for (int j=0;j<k ;j++ ) 
  21.  
  22.               { 
  23.  
  24.                      if (x[j]>n) 
  25.  
  26.                      { 
  27.  
  28.                             System.out.println("无法到达目的地!!!"); 
  29.  
  30.                             return -1; 
  31.  
  32.                      } 
  33.  
  34.                      
  35.  
  36.               } 
  37.  
  38.               for (int i=0;i<k ;i++ ) 
  39.  
  40.               { 
  41.  
  42.                      
  43.  
  44.                      s+=x[i]; 
  45.  
  46.                      if (s>n) 
  47.  
  48.                      { 
  49.  
  50.                             sum++; 
  51.  
  52.                             s=x[i]; 
  53.  
  54.   
  55.  
  56.                             } 
  57.  
  58.                      } 
  59.  
  60.               return sum; 
  61.  
  62.        } 
  63.  
  64.        public static void main(String[] args) 
  65.  
  66.        { 
  67.  
  68.               Scanner read =new Scanner(System.in); 
  69.  
  70.               System.out.println("请输入汽车加满油一次最大行驶旅程:"); 
  71.  
  72.               int n=read.nextInt(); 
  73.  
  74.               System.out.println("请输入加油站个数:"); 
  75.  
  76.               int num=read.nextInt(); 
  77.  
  78.               int a[]=new int[num]; 
  79.  
  80.               System.out.println("请输入每个加油站的相隔距离:"); 
  81.  
  82.               for (int i=0;i<num ;i++ ) 
  83.  
  84.               { 
  85.  
  86.                      a[i]=read.nextInt(); 
  87.  
  88.               } 
  89.  
  90.               int q=greedy(a,n); 
  91.  
  92.               System.out.println("要加油"+q+"次。"); 
  93.  
  94.        } 
  95.  

结果:

 

本文转自 梦朝思夕 51CTO博客,原文链接:http://blog.51cto.com/qiangmzsx/824850

转载地址:http://ftuaa.baihongyu.com/

你可能感兴趣的文章
学习知识应该像织网一样去学习——“网状学习法”
查看>>
Hadoop集群完全分布式安装
查看>>
QString,char,string之间赋值
查看>>
我的友情链接
查看>>
Nginx+mysql+php-fpm负载均衡配置实例
查看>>
MySql之基于ssl安全连接的主从复制
查看>>
informix的逻辑日志和物理日志分析
查看>>
VMware.Workstation Linux与windows实现文件夹共享
查看>>
ARM inlinehook小结
查看>>
wordpress admin https + nginx反向代理配置
查看>>
管理/var/spool/clientmqueue/下的大文件
查看>>
mysql dba系统学习(20)mysql存储引擎MyISAM
查看>>
centos 5.5 64 php imagick 模块错误处理记录
查看>>
apache中文url日志分析--php十六进制字符串转换
查看>>
浅谈代理
查看>>
基于jquery实现的超酷动画源码
查看>>
fl包下的TransitionManager的使用
查看>>
Factorialize a Number
查看>>
[USB-Blaster] Error (209040): Can't access JTAG chain
查看>>
防HTTP慢速攻击的nginx安全配置
查看>>