已阅读5页,还剩17页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
任务书课程名称:C#程序设计设计题目:银行排队叫号系统1. 问题描述: 目前,在以银行营业大厅为代表的窗口行业,大量客户的拥挤排队已成为了这些企事业单位改善服务品质、提升营业形象的主要障碍。排队(叫号)系统的使用将成为改变这种状况的有力手段。排队系统完全模拟了人群排队全过程,通过取票进队、排队等待、叫号服务等功能,代替了人们站队的辛苦,把顾客排队等待的烦恼变成一段难得的休闲时光,使客户拥有了一个自由的空间和一份美好的心情。 排队叫号软件的具体操作流程为:l 顾客取服务序号。当顾客抵达服务大厅时,前往放置在入口处旁的取号机,并按一下其上的相应服务按钮,取号机会自动打印出一张服务单。单上显示服务号及该服务号前面正在等待服务的人数。l 银行职员呼叫顾客 ,顾客的服务号就会按顺序的显示在显示屏上。当一位顾客办事完毕后,柜台银行职员只需按呼叫器相应键,即可自动呼叫下一位顾客。2. 功能要求:1)使用数组或链表以及C#接口和范型技术实现通用的队列功能;2)编写算法,利用队列模拟银行排队系统;3)利用多窗口分别模拟顾客取服务号、银行窗口服务顾客。3.界面要求:用户界面设计不做统一规定,但应做到界面友好,易于操作。 4. 技术要求:要求利用面向对象的方法以及队列数据结构来完成系统的设计;在设计的过程中,建立清晰的类层次; 在系统设计中要分析和定义各个类,每个类中要有各自的属性和方法;要求运用面向对象的机制来实现系统功能。 5创新要求在基本要求达到后,可以进行创新设计(包括界面、功能、数据结构)。6.课程设计时间:10天7.考核方式l 在机房当场验收。l 学生提交课程设计文档(A4纸打印)目录1 设计内容与要求 2.设计说明 2.1 问题描述与功能设计 2.2 算法与数据结构 2.3 类定义(函数定义) 2.4 界面设计 2.5 编码 2.6 测试3 总结附录A:源代码一、设计内容与要求1、设计内容 1)、设计窗口,服务窗口;2)、编写代码,实现各种算法,完成排队叫号问题;2、设计要求1通过这次课程设计,要求在数据结构的逻辑特性和物理表示、数据结构的选择应用、算法的设计及其实现等方面加深课程基本内容的理解。同时,在程序设计方法以及上机操作等基本技能和科学作风方面受到比较系统和严格的训练。2学生必须仔细研读数据结构课程设计任务书要求,以学生自学为主、指导教师指导为辅,独立完成课程设计的任务,有问题及时主动与指导教师沟通。3在课程设计中,学生要发挥自主学习的能力,充分利用时间,安排好课程设计的时间计划,并在课程设计过程中不断检测自己的计划完成情况,及时向指导教师汇报。4编程语言:C#语言。二、设计说明2.1问题描述与功能设计1、问题描述 目前,在以银行营业大厅为代表的窗口业务,大量客户的拥挤排队已成为了这些企事业单位改善服务品质、提升企业形象的主要障碍。排队叫号系统的使用将成为改变这种情况的有力手段。排队系统完全模拟了人群排队的全过程,通过取票进队。排队等待、叫号服务等功能,很好的解决了客户在服务机构办理业务是所遇到的各种排队、拥挤和混乱现象,代替了人们站队的辛苦,把顾客等待的烦恼变成了一段难得的休闲时光,使客户拥有了一个自由的空间和一份美好的心情。 排队叫号软件的具体操作流程为:4、顾客到窗口办理 休息区的顾客听到呼叫就到响应窗口进行一对一服务。3、营业员按钮呼叫 窗口操作员按“下一位”,当前窗口就显示顾客排队号并语音呼叫“请XX到X号窗口”2、顾客休息等待 取到排队号的顾客在休息区休息等待,注意大厅的提示信息1、顾客取号需要办理业务的顾客到取票机前取号,并获得打印出的排队号票2、功能设计1)使用数组以及C#接口和范型技术实现通用的队列功能;2)编写算法,利用队列模拟银行排队系统;3)利用多窗口分别模拟顾客取服务号、银行窗口服务顾客。2.2算法与数据结构在银行排队叫号软件中,首先要找到一种数据结构来存放顾客所得到的服务号,这些服务号表示客户的请求服务的先后顺序,也表示客户被服务的先后顺序。先来的客户被服务:在这个程序中,主要运用了队列这种结构:1、 队列是一种特殊的线性表,是一种只允许在表的一端插入操作而在另一端进行删除操作的线性表。进行插入操作的表尾称为队尾(Rear),进行删除操作的头部称为对头(Front)。当队列中没有数据元素时称为空队列(Empty Queue)。队列通常记为Q=(a1,a2,an),a1为对头元素,an为队尾元素。这n个元素是按照a1,a2,an的次序依次入队的,出队的顺序与入队顺序相同,a1第一个出队,an最后一个出队。队列的结构示意图如下: 出队 a1 a2 an 入队2、队列的特征: 队列的操作是按照“先进先出”或“后进后出” 的原则进行的。3、 队列的基本操作:(1) 入队列操作:EnQueue(T elem);(2) 出队列操作:DeQueue();(3) 取队头元素:GetFront();(4) 求队列的长度;GetLength();(5) 判断队列是否为空:IsEmpty();(6) 清空操作:Clear();(7) 判断是否为满:IsFull();在这个程序中用循环顺序队列;当队尾指示器rear到达数组上限时,如果还有数据元素入队并且数组的第0个空间空闲时,队尾指示器rear指向数组的0端。队尾指示器rear的值不一定大于队头Front的值,并且队满和队空的条件是相同的,为rear=front;2.3类定义(函数定义)在这个程序中,定义了一下及几种类:接口IQueue类:将队列的基本操作定义在接口IQueue中,如左图所示:Clear:清空操作,是队列为空;DeQueue:出队列操作,将队头元素从队列中取出;EnQueue:入队列操作,将值为elem的新数据元素添加到队尾;GetFront:取队头元素,返回队头元素的值;GetLength:求队列的长度,返回队列中数据元素的个数;IsEmpty:判断队列是否为空,如果对列为控,返回true,否则返回false;IsFull:判断是否为满,如果对列为满返回true,否则返回false;接口IBankQueue类:将银行队列的所有操作定义在里面:GetCallnumber:获取服务号; 泛型类CSeqQueue表示顺序队列:(1)、字段字段maxsize:表示循环队列的最大容量;字段front:表示对头,范围是0maxsize-1;字段rear:表示队尾,范围也是0maxsize-1;字段data:表示数组用于存储循环顺序队列中的数据 元素;(2)、属性在类中并设置了队头属性(front)、队尾属性(rear)、容量属性(maxsize)、索引器属性(this);(3)、方法在这个类中有接口IQueue中的一切方法;银行叫号顺序队列类CSeqBankQueue类:该类实现IBankQueue接口中定义的全部行为,通过继承CSeqQueue将已实现的全部行为继承过来;此外,设置了一个新来顾客的服务号属性Callnumber;通过方法GetCallnumber()获得服务号;Form1类:Form1继承了系统中的Form类;在Form1中使用了button、label、textBox等控件;使用了button_Click方法实现取号行为;Form2类:Form2也继承了系统中的Form类;在Form2中也使用了button、label、textBox等控件;使用了button_Click方法实现叫号行为;Form3类:Form3也继承了系统中的Form类;在Form2中也使用了button、label、textBox等控件;使用了button_Click方法实现叫号行为;Form4类:Form4也继承了系统中的Form类;在Form2中也使用了button、label、textBox等控件;使用了button_Click方法实现叫号行为;服务窗口ServiceWindow类:服务队列的属性BankQ;作为线程的方法Service();主程序Main()方法;2.4界面设计在这个程序中,总共设计了四个界面,一个取号界面,三个服务窗口界面:如图所示:1、取号窗口:在取号窗口中,有了三个label控件,设置了“中国银行”、“欢迎你”、“请点击取号”字样,使用button控件设置了取号按钮,用了textBox控件用于显示所取到的排队号码。2、服务窗口一号服务窗口二号服务窗口三号服务窗口在服务窗口中用了两个label控件设置了“中国银行”、“X号服务窗口”字样,用了button控件设置了“下一个”按钮,用textBox显示“请X号到X号服务窗口”;2.5编码namespace 银行排队叫号系统 public partial class Form1 : Form IBankQueue bankQueue=new CSeqBankQueue(100);/新建一个队列; CSeqQueue q1 = new CSeqQueue(100); int Callnumber;/号码; public Form1() InitializeComponent(); Form2 f1 = new Form2(this.q1);/实例话Form; Form3 f2 = new Form3(this.q1); Form4 f3 = new Form4(this.q1); f1.Show();/使几个窗口同时显示; f2.Show(); f3.Show(); private void button1_Click(object sender, EventArgs e) if (!bankQueue.IsFull() Callnumber = bankQueue.GetCallnumber(); textBox1.Text = 你的号码是: + Callnumber + 号, + 你前面还有 + bankQueue.GetLength() + 位,请耐心等待!; bankQueue .EnQueue(Callnumber );/所取得的号码进队; q1.EnQueue(Callnumber); else Console .WriteLine (现在业务繁忙,请稍后再来!); Console .WriteLine (); namespace 银行排队叫号系统 public partial class Form3 : Form CSeqQueue _q1 = new CSeqQueue(100); public Form3(CSeqQueue q1)/构造函数,应用Form1所建立的队列; InitializeComponent(); this._q1 = q1; private void button1_Click(object sender, EventArgs e) if (!_q1.IsEmpty() textBox1.Text = (请 + _q1.DeQueue() + 号到二号窗口!); else MessageBox.Show(现在没有客人!); 2.6测试代码编写完成后,执行调试-开始执行,看是否能成功生成,若能的话,点击取号看服务窗口是否按要求运作;若不能的话,根据所提供的错误提示,一步步的调试,直到成功生成为止。下图为取到八号,且六号正在被服务时各显示器上的显示:三、总结在整个过程中,应该注意以下几点:1.要求利用面向对象的方法以及队列数据结构来完成系统的设计;2. 在设计的过程中,建立清晰的类层次;3. 在系统设计中要分析和定义各个类,每个类中要有各自的属性和方法;4. 要运用面向对象的机制来实现系统功能。通过对完成这次课程设计,加深了对队列这种数据结构的理解,掌握了队列数据结构极其算法;此外也能够更加熟练的使用button。Label。textBox等控件。附录:源代码IQueue接口代码:using System;namespace QueueDs interface IQueue void EnQueue(T elem); /入队列操作 T DeQueue(); /出队列操作 T GetFront(); /取对头元素 int GetLength(); /求队列的长度 bool IsEmpty(); /判断队列是否为空 void Clear(); /清空队列 bool IsFull();/判断是否为满,在顺序队列中实现该算法,在链式队列中代码实现为空 IBankQueue接口代码:using System;namespace QueueDs interface IBankQueue:IQueue int GetCallnumber();/获得服务号码 顺序队列代码:using System;namespace QueueDs public class CSeqQueue:IQueue private int maxsize; /循环顺序队列的容量 private T data; /数组,用于存储循环顺序队列中的数据元素 private int front; /指示最近一个己经离开队列的元素所占的位置 private int rear; /指示最近一个进行入队列的元素的位置 /索引器 public T thisint index get return dataindex; set dataindex = value; /容量属性 public int Maxsize get return maxsize; set maxsize = value; /队头指示器属性 public int Front get return front; set front = value; /队尾指示器属性 public int Rear get return rear; set rear = value; /初始化队列 public CSeqQueue() public CSeqQueue(int size) data = new Tsize; maxsize = size; front = rear = -1; /入队操作 public void EnQueue(T elem) if (IsFull() Console.WriteLine(Queue is full); return; rear=(rear + 1) % maxsize; ; datarear = elem; /出队操作 public T DeQueue() if (IsEmpty() Console.WriteLine(Queue is empty); return default(T); front = (front + 1) % maxsize; return datafront; /获取队头数据元素 public T GetFront() if (IsEmpty() Console.WriteLine(Queue is empty!); return default(T); return data(front+1)%maxsize; /求循环顺序队列的长度 public int GetLength() return (rear - front + maxsize) % maxsize; /判断循环顺序队列是否为满 public bool IsFull() if (front = -1 & rear = maxsize - 1) | (rear + 1) % maxsize = front) return true; else return false; /清空循环顺序队列 public void Clear() front = rear = -1; /判断循环顺序队列是否为空 public bool IsEmpty() if (front = rear) return true; else return false; 银行顺序队列代码:using System;using System.Threading;namespace QueueDs /银行叫号顺序队列类 class CSeqBankQueue:CSeqQueue,IBankQueue private int callnumber;/记录系统自动产生的新来顾客的服务号 /叫号属性 public int Callnumber get return callnumber; set callnumber = value; public CSeqBankQueue () public CSeqBankQueue(int size):base(size) /获得服务号码 public int GetCallnumber() if (IsEmpty() & callnumber = 0) callnumber = 1; else callnumber+; return callnumber; /服务窗口类 class ServiceWindow IBankQueue bankQ; public IBankQueue BankQ get return bankQ; set bankQ = value; public void Service() while (true) Thread.Sleep(10000); if (!bankQ.IsEmpty() Console.WriteLine(); lock (bankQ) Console.WriteLine(请0号到1号窗口!, bankQ.DeQueue(), Thread.CurrentThread.Name); Form1代码using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using QueueDs;namespace 银行排队叫号系统 public partial class Form1 : Form IBankQueue bankQueue=new CSeqBankQueue(100); CSeqQueue q1 = new CSeqQueue(100); int Callnumber; public Form1() InitializeComponent(); Form2 f1 = new Form2(this.q1); Form3 f2 = new Form3(this.q1); Form4 f3 = new Form4(this.q1); f1.Show(); f2.Show(); f3.Show(); private void button1_Click(object sender, EventArgs e) if (!bankQueue.IsFull() Callnumber = bankQueue.GetCallnumber(); textBox1.Text = 你的号码是: + Callnumber + 号, + 你前面还有 + bankQueue.GetLength() + 位,请耐心等待!; bankQueue .EnQueue(Callnumber ); q1.EnQueue(Callnumber); else Console .WriteLine (现在业务繁忙,请稍后再来!); Console .WriteLine (); private void Form1_Load(object sender, EventArgs e) Form2的代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using QueueDs;namespace 银行排队叫号系统 public partial class Form2 : Form CSeqQueue _q1 = new CSeqQueue(100); public Form2(CSeqQueue q1) InitializeComponent(); this._q1=q1; private void button1_Click(object sender, EventArgs e) if (!_q1.IsEmpty () textBox1.Text = 请 +_q1.DeQueue()+ 号到一号窗口; else MessageBox.Show(现在没有客人!); private void Form2_Load(object sender, EventArgs e) Form3代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using QueueDs;namespace 银行排队叫号系统 public partial class Form3 : Form CSeqQueue _q1 = new CSeqQueue(100); public Form3(CSeqQueue q1) InitializeComponent(); this._q1 = q1; private void button1_Click(object sender, Eve
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2023年固态地振动强度记录仪投资申请报告
- 违反师德师风心得体会
- 母亲节营销活动方案8篇
- 2024年重庆市公务员考试《行测》真题及答案解析
- 体育运动员赞助协议范本
- 2024版建筑居间合同范本
- 2024海滩租赁合同
- 彩色瓦片代理合同样本
- 医院食堂食品采购协议
- 建筑工程赔偿协议样本
- animals-动物-小学趣味英语课课件
- 板块轮动与龙头股战法原理
- 雅鲁藏布江大拐弯巨型水电站规划方案
- 国家开放大学《心理与健康》形考任务1-3参考答案
- 饲料行业会计科目表B
- 河北省保定市药品零售药店企业药房名单目录
- 广西基本医疗保险门诊特殊慢性病申报表
- 分包单位资格报审表-填写模板
- 幼儿园大班科学:《树叶为什么会变黄》课件
- 马工程《马克思主义发展史》课后习题答案
- 《培养良好的卫生习惯》主题班会(30张)课件
评论
0/150
提交评论