黑马程序员技术交流社区

标题: 用java写一个喝多少瓶啤酒的算法 [打印本页]

作者: jiajun    时间: 2016-8-5 18:48
标题: 用java写一个喝多少瓶啤酒的算法
一瓶啤酒2块钱,2个空瓶可以换一瓶啤酒,4个盖子可以换一瓶啤酒,问给定一个资金,可以喝多少瓶啤酒,
算法怎么写

作者: 阿卜    时间: 2016-8-5 18:48
public class BuyBeers {

        public static void main(String[] args) {
                System.out.println(buyBeers(16,0,0));

        }
       
        public static int buyBeers(int money,int bottle,int cap) {
                //啤酒数量
                int beerNum = money / 2 + bottle / 2 + cap / 4;
                //瓶子数量(本次新买 + 不能换的余下的)
                int bottleNum = beerNum + bottle % 2;
                //瓶盖数量(本次新买 + 不能换的余下的)
                int capNum = beerNum + cap % 4;
                //总啤酒数量
                int beerSum = beerNum;
                //有2个以上瓶子或4个以上盖子
                if(bottleNum >= 2 || capNum >= 4) {
                        beerSum += buyBeers(0,bottleNum,capNum);
                }
                return beerSum;
        }
}
作者: 刘小白    时间: 2016-8-5 19:27

作者: 樱释空    时间: 2016-8-5 23:08
我给你看看哈
作者: 樱释空    时间: 2016-8-5 23:13
我给你看看哈public class demo10 {         public static void main(String[] args) {                 int n=7;//人数                 System.out.println(n+"人共需要买:"+getCount(n)+"瓶");         }         public static int getCount(int n){                 int sum = 0;//用于记录当前啤酒总数                 int sum2 = 0;//用于记录当前啤酒总数                 int count = 0;//用于记录购买的啤酒数                                  while(sum<n){                         count++;                         sum++;                         if(sum%4==0 || sum%2==0){                                 sum++;                         }                 }                 return count;         } }
作者: 樱释空    时间: 2016-8-5 23:19
public class demo10 {
        public static void main(String[] args) {
                int n=7;//人数
                System.out.println(n+"人共需要买:"+getCount(n)+"瓶");
        }
        public static int getCount(int n){
                int sum = 0;//用于记录当前啤酒总数
                int sum2 = 0;//用于记录当前啤酒总数
                int count = 0;//用于记录购买的啤酒数
               
                while(sum<n){
                        count++;
                        sum++;
                        if(sum%4==0 || sum%2==0){
                                sum++;
                        }
                }
                return count;
        }
}
作者: 敲敲敲dm    时间: 2016-8-5 23:28
递归 思路 辛辛苦苦半天敲的都是 新手,求给我 ,多思考,多敲,多学习我们一起进步:
import java.util.Scanner;


public class Demo_Count {
        public static void main(String[] args) {
                Scanner sc = new Scanner(System.in);
                int x  = sc.nextInt();
                int sum = count(x);
                System.out.println("一共能换"+sum+"瓶");
        }
//        思路:先用<4块钱>买2瓶酒(剩2个瓶子,2个盖子),
//        用(2个瓶子)换1瓶酒(剩1个瓶子,3个盖子);
//        再用<2块钱>买1瓶酒(剩2个瓶子,4个盖子),
//        用(2个瓶子,4个盖子)换2瓶酒(剩2个瓶子,2个盖子),
//        用(2个盖子)换1瓶酒(剩1个瓶子,3个盖子);
//        再用<2块钱>买1瓶酒(剩2个瓶子,4个盖子),
//        用(2个瓶子,4个盖子)换2瓶酒(剩2个瓶子,2个盖子),
//        用(2个瓶子)换1瓶酒(剩1个瓶子,3个盖子);

//  上边循环 ,然后又由于 1块钱买不酒 对题目无影响,所以 算法如下
//   4 块钱3瓶 剩1 瓶三盖
        public static int count(int x){
                int sum = 0 ;
                if(x<3){
                        sum = x/ 2;
                }else{
                        //4块 买一 换2 ++++++因为以后都是1瓶3盖,所以买1换2+换1====每两块买1换3;
                        sum = 3 +(x-4)/2*4;
                }
               
                return sum;
               
        }
}
作者: jiajun    时间: 2016-8-5 23:57
樱释空 发表于 2016-8-5 23:19
public class demo10 {
        public static void main(String[] args) {
                int n=7;//人数

你这个没看懂啊,能把思路说下么,结果好像有点不对。
作者: jiajun    时间: 2016-8-6 00:04
敲敲敲dm 发表于 2016-8-5 23:28
递归 思路 辛辛苦苦半天敲的都是 新手,求给我 ,多思考,多敲,多学习我们一起进步:
import java.util.Sc ...

大神,感觉你数学很好,思路很棒,问一下能不能用代码模拟这个过程?
作者: jiajun    时间: 2016-8-6 19:07
大神,能加个好友吗,很厉害,我一直没想到可以同时把剩余瓶盖数和剩余瓶子数当参数传递给下一次递归函数使用,厉害厉害,学习了。
作者: jiajun    时间: 2016-8-6 19:09
阿卜 发表于 2016-8-5 18:48
public class BuyBeers {

        public static void main(String[] args) {


大神,能加个好友吗,我一直在想怎么同时把剩余瓶盖数和剩余瓶子数当参数传递给下一次递归函数使用,没想到,厉害厉害,学习了。
作者: 樱释空    时间: 2016-8-6 23:34
jiajun 发表于 2016-8-5 23:57
你这个没看懂啊,能把思路说下么,结果好像有点不对。

这个可以用Scanner输入啊,结果肯定对,不对剁手.
作者: 敲敲敲dm    时间: 2016-8-9 23:00
阿卜 发表于 2016-8-5 18:48
public class BuyBeers {

        public static void main(String[] args) {

学习学习学习学习学习谢谢
作者: absvir    时间: 2016-8-26 21:53
我的笔试题有这个
作者: 爱你一万年    时间: 2016-9-11 23:07
阿卜 发表于 2016-8-5 18:48
public class BuyBeers {

        public static void main(String[] args) {

屌屌屌屌屌屌




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2