已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
武汉纺织大学数据结构实验报告班级: 12 级 专业 班 姓名: 序号: 实验时间: 2014 年 4 月 4 日 指导教师: 宋泽源 实验一:线性结构的基本操作一、实验目的: 1、熟悉Java 上机环境,掌握Java语言编程方法,熟练运用Java语言实现数据结构设计和算法设计。2、掌握线性表的顺序存储结构和链式存储结构的定义与基本操作,并能用Java语言实现线性表基本功能。3、掌握栈、队列的存储结构与基本操作,并能利用该结构编写算法解决实际问题。二、实验内容: 1、编写一个Java语言程序,利用线性表实现约瑟夫环问题,参考书本程序示例【例2.1】,完善该程序并运行。 实验步骤: 、在Java编辑环境中新建程序,根据【例2.1】输入完整程序内容,并保存和编译; 、运行程序,输入约瑟夫环长度number、起始位置start、计数值distance; 、依次输入约瑟夫环中number个数据元素; 、输出约瑟夫环执行过程。2、编写一个程序,利用栈解决递归问题,实现n阶Hanoi塔问题。 实验步骤: 、在Java编辑环境中新建程序,输入n阶Hanoi塔程序内容,并保存和编译; 、运行程序,输入盘子数目n。 、输出n阶Hanoi塔问题解决过程。参考程序如下:import java.util.Scanner;public class MethodOfHanoipublic static void main(String args)System.out.println(“请输入盘子数目:”);Scanner scan=new Scanner(System.in); /输入盘子数目int number=scan.nextInt();hanoi(number,A,B,C); /调用hanoi方法public static void hanoi(int num, char a,char b,char c)if (num=1) /只有一个盘子,直接移动 move(a,c);elsehanoi(num-1,a,c,b); /递归调用move(a,c);hanoi(num-1,b,a,c); /递归调用 public static void move(char a,char c) /移动过程方法 System.out.println(从 +a+ 移到 +c); 3、编写一个程序,利用Java语言建立一个空队列,如果输入奇数,则奇数入队列;如果输入偶数,则队列中的第一个元素出队列;如果输入0,则退出程序。 实验步骤: 、在Java编辑环境中新建程序,输入程序内容,并保存和编译; 、运行程序,输入数据并进行相应队列操作。 、输出每次输入数据后的队列结果。三、操作步骤:1代码:import java.util.ArrayList;import java.util.List;public class YSfhpublic YSfh(int number, int start, int distance) List list = new ArrayList(number);for (int i = 0; i 1) i = (i + distance - 1) % list.size();System.out.print(删除 + list.remove(i).toString() + ,);System.out.print(list.toString();System.out.print(被赦免者是 + list.get(0).toString();public static void main(String args) new YSfh(5, 0, 2);运行结果:2.代码:import java.util.Scanner;public class MethodOfHanoipublic static void main(String args)System.out.println(请输入盘子数目:);Scanner scan=new Scanner(System.in); /输入盘子数目int number=scan.nextInt();hanoi(number,A,B,C); public static void hanoi(int num, char a,char b,char c)if (num=1) /只有一个盘子,直接移动 move(a,c);elsehanoi(num-1,a,c,b); /递归调用move(a,c);hanoi(num-1,b,a,c); /递归调用 public static void move(char a,char c) /移动过程方法 System.out.println(从 +a+ 移到 +c); 运行结果:3.代码QQueue.javapublic interface QQueue boolean isEmpty();boolean enqueue(T x);T dequeue();SeqQueue.javapublic class SeqQueue implements QQueue private Object element;private int front, rear;public SeqQueue(int length) if (length 64)length = 64;this.element = new ObjectMath.abs(length);this.front = this.rear = 0;public SeqQueue() this(64);public boolean isEmpty() return this.front = this.rear;public boolean enqueue(T x) if (x = null)return false;if (this.front = (this.rear + 1) % this.element.length) Object temp = this.element;this.element = new Objecttemp.length * 2;int i = this.front, j = 0;while (i != this.rear) this.elementj = tempi;i = (i + 1) % temp.length;j+;this.front = 0;this.rear = j;return true;this.elementthis.rear = x;this.rear = (this.rear + 1) % this.element.length;return true;public T dequeue() if (isEmpty()return null;T temp = (T) this.elementthis.front;this.front = (this.front + 1) % this.element.length;return temp;public String toString() String str = (;if (!isEmpty() str += this.elementthis.front.toString();int i = (this.front + 1) % this.element.length;while (i != this.rear) str += , + this.elementi.toString();i = (i + 1) % this.element.length;return str + );ts3.javaimport java.util.Scanner;public class ts3public static void main(String args) Scanner in = new Scanner(System.in);SeqQueue queue = new SeqQueue(64);int num = -1;while(num != 0) num = in.nextInt();if (num % 2 = 0) if (queue.dequeue() = null) System.out.println(当前队列为空!); else if (!q
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 电工等级考试题库及答案
- 配电工考试题库及答案
- 售后服务流程管理客户满意度提升版
- 技术会议活动内容及准备工作表含场地预约标准步骤
- 2025年机器人行业技术创新与产业应用研究报告及未来发展趋势预测
- 2025年农业科技行业数字农业技术应用与农业发展研究报告及未来发展趋势预测
- 智能家居安全便捷体验承诺书8篇范文
- 会议组织与策划执行工具箱
- 会计从业资格考试卷分ab卷及答案解析
- b2从业资格证模似考试及答案解析
- 2024年个人信用报告(个人简版)样本(带水印-可编辑)
- 智能设计完整版本
- 在线网课知慧《美国史(东北师大)》单元测试考核答案
- 医学检验技术职业生涯发展报告
- 护理职业规划大赛
- 安全生产投入台账(模板)
- 医保智能审核系统解决方案
- ktv地震应急预案
- 急性酒精中毒护理课件
- 营养强化食品中叶酸稳定性的评价方法
- 农村水电站标识标志标线设置及设备着色规范
评论
0/150
提交评论