初碰Java-2——游戏生命力购买问题
时间:2023-10-23 01:07:01
购买游戏活力的问题
案例描述
在一场名为Game在游戏中,作为一个玩家,你手头有几枚金币。为了增加活力,你需要买两件珍宝:仙女草和银河梭。每件仙女草的价格20金币,可以增加玩家30单位生命力;银河梭每个价格16金币可以增加玩家20单位的活力。
编程求出一种最佳购买方案,使得用你的金币购买的宝物能够最大限度地增加你的生命力(不一定要用完所有的金币),并输出最佳方案中每件宝物的购买数量。
在编写代码之前,先说想法
通过案例描述,我们可以得出下表:
名称 | 售价 | 增加生命力 |
---|---|---|
仙女草 | 20金/个 | 30单位生命力 |
银河梭 | 16金/个 | 20单位生命力 |
仙女草的数量为X,银河梭为Y,初始金币量为M,总生命力为H,可得:
H=30*X 20*Y,M=20*X 16*Y,故Y=(M-20*X)/16.
因此,当仙女草数量为X时,银河梭是(M-20*X)/16.以下是我的编码思路:
import java.util.Scanner;///包中包装数据流的主要操作java.util包 public class j29 {
////游戏中生命力的购买 public static void main(String[] args) {
int numGrass=0;///仙女草数量 int numYhsuo=0;//银河梭数量 int Money;///初始金币量 int Hp=0;//生命力 System.out.println("请输入您拥有的金币量"); Scanner m=new Scanner(System.in);////输入对象初始金币量 Money=m.nextInt(); for(int i=0,k=0,newHp=0;i<=Money/20;i ){
///计算最大生命力方案 k=(Money-20*i)/16; newHp=30*i+20*k;//目前方案的生命力 if(newHp>Hp){
numGrass=i;numYhsuo=k;Hp=newHp;}//目前生命力是否大于上个方案 } System.out.println("增加的生命力最大值为"+Hp); System.out.println("所需仙女草为"+numGrass+"个"); System.out.println("所需银河梭为"+numYhsuo+"个"); } }
首先用javac
对程序进行编译
这里我曾遇到一个问题就顺便提一下吧,假如我们编写的代码在文本文档中有中文注释可能会遇到我上篇文章<初碰Java-1_满目代码皆为你的博客-CSDN博客>所遇到问题==错误:编码GBK 的不可映射字符==,对此我们可以用javac -encoding UTF-8 文件名
来进行编译,具体可参考http://blog.csdn.net/l1028386804/article/details/46583279
编译无误,下一步试运行
以上便是我对此案例的见解