- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
java使用数组和链表实现队列示例
队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,只允许在表的后端(rear)进行插入操作,下面介绍一下java使用数组和链表实现队列的示例
(1)用数组实现的队列:
复制代码 代码如下:
//先自己定义一个接口 public interface NetJavaList { public void add(Student t); //继承该接口的类必须实现的方法 public Student get(int index);//队列的加入,取出,队列的大小 public int size(); }
定义一个学生类
复制代码 代码如下:
class Student { private String name ; //私有属性 名字,学分 private int score ; public Student(String name , int score){ = name ; this.score = score ; } public void printInfo(){ System.out.println(姓名+name + 学分+score ) ; } }
实现自定义接口
复制代码 代码如下:
public class STList implements NetJavaList{ private Student[] str = new Student[0] ; //增加队列的元素 public void add(Student t) { Student[] src = new Student[str.length+1]; for(int i=0;istr.length;i++){ src[i]=str[i] ; } src[str.length]=t ; str = src ; } //得到队列中的某个元素 public Student get(int index) { Student t = str[index]; return t; } //返回队列的长度 public int size() { return str.length; } }
写个主函数类实现下队列
复制代码 代码如下:
public class Manager { public static void main(String[] args) { STList sil = new STList() ; for(int i=0;i5;i++){ Student st = new Student(name+i,i*10); sil.add(st); } printList(sil) ; } //输出队列中的所有元素 public static void printList(STList t){ for(int i=0;it.size();i++){ Student f =t.get(i); f.printInfo(); } } }
(2)链表实现的队列先定义一个节点类;
复制代码 代码如下:
public class LinkNode { private Object obj ; //节点内的数据对象 private LinkNode next ; //对下一个节点的引用 //在创建节点对象的时候就传入节点的数据对象 public LinkNode(Object obj){ this.obj = obj ; } public Object getObj(){ return obj ; } public void setObj(Object obj){ this.obj = obj ; } public LinkNode getNext(){ return next ; } public void setNext(LinkNode next){ this.next =next ; } }
然后写个队列的实现方法类
复制代码 代码如下:
public class LinkList { public static LinkNode root ;//第一个节点 public LinkNode last = null ;//最后的一个节点 public static void main(String ara[]){ LinkList df = new LinkList() ; df.add(1); df.add(2); df.add(3); df.printLinkList(root); df.move(root,2)
您可能关注的文档
- 2015-2016 学年 人教版 必修三 第5课时 课件 (33张)...ppt
- IE七大手法之动作改善法.ppt
- html5css3网页设计教程.ppt
- 2015-2016-1期中四年级.ppt
- 2015-2016 学年 人教版 必修三 第5课时 课件 (55张)...ppt
- IHE测试培训-心电学.ppt
- ICU气管插管术-王培栋-培训.ppt
- 2015-2016一模4生产实际分析.docx
- IM - Maintenance.ppt
- 2015-2016人教版数学六上1.2《一个数乘分数的意义及分数乘分数》ppt课件.ppt
- idea Pad U450P 硬件规格和拆装指导.ppt
- 2015-2016学年山东日照东港实验学校八年级数学课件:16《二次根式》(新人教版下册).ppt
- 2015-2016学年山东日照东港实验学校八年级数学课件:17《勾股定理》1(新人教版下册).ppt
- 2015-2016学年山东日照东港实验学校八年级数学课件:17《勾股定理》2(新人教版下册).ppt
- JAVASE的基本语法.pptx
- java二叉树代码.doc
- java txt 转word.doc
- java实现二叉树查找树.docx
- IOS企业宣传模板 (多彩).pptx
- 2015-2016学年山东日照东港实验学校八年级数学课件:17《勾股定理》3(新人教版下册).ppt
最近下载
- 引领时尚潮流的可持续时尚品牌.pptx VIP
- 一年级道德与法治教案(全套).pdf VIP
- 版鲁科版英语四年级上册教案.doc VIP
- 一种脱除1,3-丙二醇中微量醛基杂质的脱除方法.pdf VIP
- 国投证券-宁德时代-300750-全球锂电行业龙头全球化布局推动发展.pdf VIP
- 2023-2024学年上海市向明中学高二上学期10月月考数学试卷含详解.docx VIP
- 《婴幼儿动作发展与训练》教案 第8课 2~3岁幼儿精细动作的发展与训练.docx VIP
- MT-500系列说明书(济南华电)-20101216.pdf
- 养成亲社会行为++课件-2025-2026学年统编版道德与法治八年级上册.pptx VIP
- 开学第一课-初中开学第一课班会.ppt VIP
文档评论(0)