脑力风暴之小毛驴历险记(1)----好多胡萝卜(下)

     我是人类工业革命后的新物种,科技研究上的奇葩,人类DNA的重新突变进化,拥有无与伦比的耐力、超越时代的智商、横穿社会的苦逼相和低于人类平均寿命等显著优点。

    是的,没错,我就是程序猿.

    每次遇到一个人,我都有着如此歇斯底里式的自我介绍,详细而不乏概要,理性而不缺感知.

   "早上好,程先生!"

   "早上好,你叫我序猿就行"

   早上刚吃过饭走出大门,遇到小毛驴,它正欢快的向城里走,看到我,于是就简单扼要的打了招呼,作为一名XX型的程序猿,一切都必须要简单扼要,能省就省,能够看到一个名字不过一个ID号而已,要知道一切不过是1和0的有序组合.

   一个XX型的程序员按照level的高级依次为:文弱Geek型,技术大牛型,还有就是苦逼码字型.

   显然我等级还比较低,由于前几天有点小忙,一直没有解决小毛驴的胡萝卜问题,昨晚忽然想起,如同将要LogOff下班回家时候,忽然发现一个Bug.一身冷汗暗暗涌出,

    当然,一个XX型的程序猿的慌张不会表现在脸上,我昨晚只是略微后仰,翘着二郎腿最好,然后在后仰的情况下低着头,以便看到屏幕,然后就不要再动了.略一深阖,忽而猛地瞪起双目,只是两手轻轻敲出一段代码,方知还是个活物.

    约莫花掉一个钟头解决掉这个问题,习惯性抬头一望,依旧没剩下几个人,然后如同往常一般找一个更苦逼的程序猿,重复了一句:"你进度太慢了啊,不要老让我等你,我先回家了"

    于是.骑着我的二八小车在辉煌的路灯中悠悠的回家.

    还好我昨天想起了小驴的难题,作为一名寡言型的程序猿,一般的话题就只有异常BUG,Realease之类.今天见了小驴,果然还是有点话题的,:"小驴啊,前几天咱们说的那个问题,我有了解决方案了啊,给你看看"

 

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ass
{
    class Ass
    {
        int forwardDistance = 0;

        //计算剩余最大的胡萝卜量
        public int maxCarrot(int totalAmount)
        {
            //如果胡萝卜小于总路程,return -1,即小毛驴穿不过沙漠
           if (totalAmount < 1000)
            {
                return totalAmount = -1;
            }

            else
            {
               //times: 将1000公里分几次走完
                int times = 0;
               //if总量 是1000的整数倍时,能满足每次前进都可以运输小毛驴的最大量1000
                if ((totalAmount % 1000) == 0)
                {
                    times = totalAmount / 1000;
                    for (int i = 1; i <= times; i++)
                    {
                        Console.WriteLine("这是第"+i+"运输:");
                        totalAmount = getAmount(totalAmount, (2 * (totalAmount / 1000) - 1));
                        Console.WriteLine("这次运输完成后还剩余" + totalAmount + "胡萝卜");
                    }

                        return totalAmount;
                }
                //else 总量不是1000的时,某次运输可能不能满足运送的最大量,这时就要比较为了剩余的胡萝卜 再返回去值不值得。
                //FE:某次出发点剩余100胡萝卜,返回200公里去取,放弃剩余的胡萝卜
                else
                {
                    int totalAomunt1 = 0;
                    times = totalAmount / 1000;
                    totalAomunt1 = totalAmount - totalAmount % 1000;
                    for (int i = 1; i <= times; i++)
                    {
                        totalAomunt1 = getAmount(totalAomunt1, (2 * (totalAomunt1 / 1000) - 1));
                    }
                    int totalAmount2 = totalAmount;
                    forwardDistance = 0;
                    times = totalAmount / 1000 + 1;
                    for (int i = 1; i<=times;i++){
                        totalAmount2 = getAmount(totalAmount2, (2 * (totalAmount2 / 1000) + 1));
                    }
                    if (totalAomunt1 < totalAmount2)
                        totalAmount = totalAmount2;
                    else
                        totalAmount = totalAomunt1;
                    return totalAmount;
                }
            }
        }
        //计算每次运输过程中前进的公里数,以及剩余的胡萝卜总量
        public int getAmount(int total,int goABtimes) {
                forwardDistance = 1000 / goABtimes + forwardDistance;
                total = total - 1000;
                //最后一次运输,
                //if (forwardDistance -1000>0),最后行走800公里,剩余200公里,还有900胡萝卜,可行走900公里,
                //显然应将多走(800+900-1000)的部分加上
                if (forwardDistance > 1000)
                {
                    Console.WriteLine("最后一次运输,剩余的胡萝卜可多走:"+(forwardDistance-1000)+"公里");
                    total = total + (forwardDistance - 1000) * goABtimes;
                }
             return total;        
        }
        static void Main(string[] args)
        {

            Console.WriteLine(new Ass().maxCarrot(2900));
            Console.ReadKey();
        }


    }
}


 小驴看了,吐了吐舌头,:"貌似很复杂哇"

   我说:"我主要是考虑了你胡萝卜总量的变化,不仅3000时候可用这个计算,其它任何量都可以计算啊"

   小驴蔑视了我一眼:"看看,看看,需求分析没做好吧,我只有3000根胡萝卜那来这么多变化的胡萝卜啊,白白增加了逻辑复杂度,算了,时间来不及了,就这样吧"

    我一阵无语,习惯性的点燃一支烟,正要争辩.,小驴见了立刻大叫:"最烦抽烟的人了,不知道这是慢性自杀么!"

   我蔑视了他一眼,抽了口烟:"永远不要警告程序猿,作为一名程序猿,他永远不理会警告(waring),只会在意错误(error)"

    小驴挥了挥手:"得了,得了,收起你那套歪道道吧,我要去领奖励你去不?"

    我一阵大喜:"国王的奖励吗?必须去啊!"

    于是,同去,同去!

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值