C#实现倒油算法
原题如下: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#实现倒油算法的更多相关文章
- 二、油泼面(Oil spill noodle)
油泼面 油泼面是陕西传统的特色面食之一,起源于周代,并以咸阳油泼面最为著名,有鲜香味.酸辣味.香辣味. 油泼面是一种很普通的面食制作方法,将手工制作的面条在开水中煮熟后捞在碗里,将葱花碎.花椒粉.盐等 ...
- NLP-BM25算法理解
前两天老师给我们讲解了BM25算法,其中包括由来解释,以及算法推导,这里我再将其整理,这里我不讲解之前的BIM模型,大家有兴趣可以自行了解.Okapi BM25:一个非二值的模型bm25 是一种用来评 ...
- 设计模式(十四)模板方法模式(Template Pattern)
一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...
- C#设计模式-模板方法模式
提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简历模板,下 ...
- 模板方法模式(Template Method)
一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...
- 14.模板方法模式(Template Method)
using System; namespace ConsoleApplication7 { class Program { /// <summary> /// 模板方法模式——在一个抽象类 ...
- C#设计模式(14)——模板方法模式(Template Method)
一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等,在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它,例如简 ...
- 【15】模板方法模式(Template Method)
一.引言 提到模板,大家肯定不免想到生活中的“简历模板”.“论文模板”.“Word中模版文件”等.在现实生活中,模板的概念就是——有一个规定的格式,然后每个人都可以根据自己的需求或情况去更新它.例如简 ...
- DesignPattern(五)行为型模式(上)
行为型模式 行为型模式是对在不同对象之间划分责任和算法的抽象化.行为模式不仅仅关于类和对象,还关于它们之间的相互作用.行为型模式又分为类的行为模式和对象的行为模式两种. 类的行为模式——使用继承关系在 ...
随机推荐
- java 学习笔记——类之间的关系之封装、继承与多态的详解
封装 一个封装的简单例子 封装就是把对象的属性(状态)和方法(行为)结合在一起,并尽可能隐蔽对象的内部细节,成为一个不可分割的独立单位(即对象),对外形成一个边界,只保留有限的对外接口使之与外部发生联 ...
- Apache ab测试工具使用方法(无参、get传参、post传参)
Ab测试工具是apache自带的测试工具,具有简单易上手的特性,下面我总结一下我的使用方法,首先去官方下载apache程序包,我下的最新版本apache2.4.23,下载地址http://httpd. ...
- Java高级工程师进阶路线
第一部分:宏观方面 一. JAVA.要想成为JAVA(高级)工程师肯定要学习JAVA.一般的程序员或许只需知道一些JAVA的语法结构就可以应付了.但要成为JAVA(高级) 工程师,您要对JAVA做比较 ...
- M-定在下边的区域
1 效果 2 布局 3 样式
- zoj3211dream city dp 斜率
Dream City Time Limit: 1 Second Memory Limit:32768 KB JAVAMAN is visiting Dream City and he see ...
- structs2的核心和工作原理
在学习struts2之前,首先我们要明白使用struts2的目的是什么?它能给我们带来什么样的好处? 设计目标 Struts设计的第一目标就是使MVC模式应用于web程序设计.在这儿MVC模式的 ...
- HTML与标记属性
网站部分:UI:AI.PS 前端:html.css.js 网站:是一个存放在网络服务器上的完整信息的集合体.由域名.空间服务器.网站程序.数据库等组成.由多个网页以一定的方式连接在一起,成为一个整体. ...
- wpf 画刷的分类
System.Windows.Media.Brush最上一层画刷 System.Windows.Media.GradientBrush 线性画刷 ,下层主要有两种画刷 System.Windows. ...
- RAID 构建
RAID的创建 第一步:先查看我们系统的磁盘情况 [root@station40 ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT sda ...
- [Python] 文科生零基础学编程系列三——数据运算符的基本类别
上一篇:[Python] 文科生零基础学编程系列二--数据类型.变量.常量的基础概念 下一篇: ※ 程序的执行过程,就是对数据进行运算的过程. 不同的数据类型,可以进行不同的运算, 按照数据运算类型的 ...