原题如下:12(a桶 满的 有12斤油)斤桶里 取出6斤油 有 另外有8斤(b桶)和5斤(c桶)两个空桶  让程序输出取出这6斤油的步骤

现在实现的算法可以配参数(定义有几个桶,初始有多少油,要得到多少油,都可以配),并且找出任意(多条线路或者找不到)满足条件的倒油线路图:

运行效果:

using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace ConsoleApplication2{class Program    {static void Main(string[] args)        {//在此自定义相关初始信息            Oil.初始油量 = "12,0,0";            Oil.桶的容量 = "12,8,5";            Oil.需求油量 = "6";            Oil oil = new Oil();            Status SuperStatus = oil.GetStartState();            oil.status.Add(SuperStatus);            oil.执行(SuperStatus);if (oil.Endstatus.Count == 0)            {                Console.WriteLine("无法倒出指定质量大小的油。");            }else            {                Console.WriteLine("共找到" + oil.Endstatus.Count.ToString()+"条倒油线路:");            }for (int i = 0; i < oil.Endstatus.Count; i++)            {                Console.WriteLine(oil.翻译路线(oil.Endstatus[i]));            }        }    }class Oil    {public static string 桶的容量;public static string 初始油量;public static string 需求油量;//自动记录桶的总数int count;public Oil()        {            count = 桶的容量.Split(',').Count();            capacity = new int[count];for (int i=0;i<count;i++)            {                capacity[i] = Convert.ToInt32(桶的容量.Split(',')[i]);            }        }public int[] capacity; //new int[] { 12, 8, 5 };public List<Status> status = new List<Status>();public List<Status> Endstatus = new List<Status>();        Status 倒油(Status state, int a, int b)        {//排除不可倒的情况if (state.OilState[a] == 0return null;if (state.OilState[b] == capacity[b]) return null;//倒油操作//先定义成功倒油后的新状态            Status newStatus = new Status();            newStatus.OilState = new int[count];            state.OilState.CopyTo(newStatus.OilState, 0);            newStatus.Father = state;if (state.OilState[a] > capacity[b] - state.OilState[b])            {                newStatus.OilState[a] -= capacity[b] - state.OilState[b];                newStatus.OilState[b] = capacity[b];            }else            {                newStatus.OilState[a] = 0;                newStatus.OilState[b] += state.OilState[a];            }//判断倒油后的新状态是否在状态列表中存在bool IsExist = false;foreach (var s in status)            {bool mark = true;for (int i = 0; i < newStatus.OilState.Count(); i++)                {if (newStatus.OilState[i] != s.OilState[i]) mark = false;                }if (mark)                {                    IsExist = true;break;                }            }if (IsExist)            {return null;            }else            {                status.Add(newStatus);return newStatus;            }        }public void 执行(Status SuperStatus)        {//如果找到一条路线if (SuperStatus.OilState.Contains(Convert.ToInt32(需求油量)))            {                Endstatus.Add(SuperStatus);                ArrangeStatus();                执行(GetStartState());return;            }for (int a = 0; a < count; a++)            {for (int b = 0; b < count; b++)                {if (b != a)                    {                        Status newStatus = 倒油(SuperStatus, a, b);if (newStatus != null)                        {                            执行(newStatus);                        }                    }                }            }        }public string 翻译路线(Status endState)        {string theWay = string.Empty;            Status s = endState;while (s != null)            {string wayNode = string.Empty;foreach (var a in s.OilState)                {                    wayNode += a.ToString() + " ";                }if (theWay == string.Empty) theWay += wayNode;else theWay = wayNode.Trim() + "→" + theWay;                s = s.Father;            }return theWay;        }/// <summary>/// 整理状态表,为寻求新路线做准备/// </summary>public void ArrangeStatus()        {            status.Clear();for (int i = 0; i < Endstatus.Count; i++)            {                Status s = Endstatus[i];while (s != null)                {                    status.Add(s);                    s = s.Father;                }            }        }/// <summary>/// 获取开始状态/// </summary>/// <returns></returns>public Status GetStartState()        {            Status status = new Status();            status.Father = null;            status.OilState = new int[count];for (int i = 0; i < count; i++)            {                status.OilState[i] = Convert.ToInt32(初始油量.Split(',')[i]);            }return status;        }    }/// <summary>/// 记录各桶当前所装油量的状态信息/// </summary>class Status    {public int[] OilState;public Status Father;    }}

C#实现倒油算法的更多相关文章

  1. 二、油泼面(Oil spill noodle)

    油泼面 油泼面是陕西传统的特色面食之一,起源于周代,并以咸阳油泼面最为著名,有鲜香味.酸辣味.香辣味. 油泼面是一种很普通的面食制作方法,将手工制作的面条在开水中煮熟后捞在碗里,将葱花碎.花椒粉.盐等 ...

  2. NLP-BM25算法理解

    前两天老师给我们讲解了BM25算法,其中包括由来解释,以及算法推导,这里我再将其整理,这里我不讲解之前的BIM模型,大家有兴趣可以自行了解.Okapi BM25:一个非二值的模型bm25 是一种用来评 ...

  3. 设计模式(十四)模板方法模式(Template Pattern)

    一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...

  4. C#设计模式-模板方法模式

    提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简历模板,下 ...

  5. 模板方法模式(Template Method)

    一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...

  6. 14.模板方法模式(Template Method)

    using System; namespace ConsoleApplication7 { class Program { /// <summary> /// 模板方法模式——在一个抽象类 ...

  7. C#设计模式(14)——模板方法模式(Template Method)

    一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...

  8. 【15】模板方法模式(Template Method)

    一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等.在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它.例如简 ...

  9. DesignPattern(五)行为型模式(上)

    行为型模式 行为型模式是对在不同对象之间划分责任和算法的抽象化.行为模式不仅仅关于类和对象,还关于它们之间的相互作用.行为型模式又分为类的行为模式和对象的行为模式两种. 类的行为模式——使用继承关系在 ...

随机推荐

  1. Vue使用总结

    好久没更新博客,确实是自己已经懒癌晚期,最近毕业刚工作3个月,公司开发一直在用Vue,自己个人也比较喜欢这个框架,今天就对自己学习到和用到的知识点作一些总结,希望能帮到大家. Vue 知道Vue也一定 ...

  2. git 忽略文件夹

    $ vim .gitignore 添加要忽略的文件或文件夹 esc + :wq 退出vim命令行

  3. 浅析php curl_multi_*系列函数进行批量http请求

    何起: 一系列 数量很大 数据不热 还希望被蜘蛛大量抓取的页面,在蜘蛛抓取高峰时,响应时间会被拉得很高. 前人做了这样一个事儿:页面分3块,用3个内部接口提供,入口文件用curl_multi_*系列函 ...

  4. Linux基础命令讲解(二)

    Linux命令基本格式: 命令 [参数] [路径文件] 方括号内容可省略 查看命令帮助手段: 1 man 命令名 (man 还可以获取配置文件,函数的帮助) 2 命令 --help 3 help 命令 ...

  5. 验证代理IP

    ##author:wuhao#import urllib.requestfrom http import cookiejar import xlrd import threading #有效的代理,可 ...

  6. NopCommerce 3. Controller 分析

    1. 继承关系,3个abstract类 System.Web.Mvc.Controller Nop.Web.Framework.Controllers.BaseController Nop.Admin ...

  7. win10 uwp 异步进度条

    本文主要讲我设计的几个进度条,还有如何使用异步控制进度条,如何使用动画做进度. 进度条可以参见:http://edi.wang/post/2016/2/25/windows-10-uwp-modal- ...

  8. UWP上可用的GB2312编码

    大概是在WP8的时候,网上有一个WP8可用的GB2312编码的解决方法,就是那个DBCSCodePage. 但是由于UAP开始,微软删掉了GetManifestResourceStream,所以这东西 ...

  9. 《Unity3D/2D游戏开发从0到1(第二版本)》 书稿完结总结

    前几天,个人著作<Unity3D/2D游戏开发从0到1(第二版)>经过七八个月的技术准备以及近3个月的日夜编写,在十一长假后终于完稿.今天抽出一点时间来,给广大热心小伙伴们汇报一下书籍概况 ...

  10. 程序员节应该写博客之.NET下使用HTTP请求的正确姿势

    程序员节应该写博客之.NET下使用HTTP请求的正确姿势 一.前言 去年9月份的时候我看到过外国朋友关于.NET Framework下HttpClient缺陷的分析后对HttpClient有了一定的了 ...