栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java使用数组和链表实现队列示例

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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){ 
        this.name = 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;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;i<5;i++){ 
        Student st = new Student("name"+i,i*10);     
        sil.add(st); 
        } 
       printList(sil) ; 

    } 
//输出队列中的所有元素 
  public static void printList(STList t){ 
      for(int i=0;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) ; 
        df.move(root,2) ; 
        df.printlinkList(root); 

    } 
     
    public void add(Object obj){ 
        //创建一个新的节点 
        linkNode t = new linkNode(obj); 
        if(root ==null){ 
            root = t ; 
            last = root ; 
        }else{ 
            last.setNext(t); 
            last = t ; 
        } 

    } 
     
    public void printlinkList(linkNode root){ 
        if(null != root){ 
            Object data = root.getObj(); 
            System.out.println(data); 
            linkNode temp = root.getNext(); 
            printlinkList(temp) ; 
        } 
    } 
     
    public linkNode move(linkNode root,int index){ 
        if(this.getLength()            throw new RuntimeException("下标越界:"+index + 
                ",size:" +this.getLength()) ; 
        }else{ 
        int count = 1 ;linkNode sd = root ; 
         while(count!=index-1){ 
             sd = sd.getNext(); 

         } 

         
         sd.setNext(sd.getNext().getNext()); 
        return root ; 
    }} 

    
      public int  getLength(){ 
        int count = 0 ; 
        if(root==null){ 
            return count ; 
        } 
        linkNode node =root.getNext(); 
        while(null != node){ 
            count ++ ; 
            node=node.getNext(); 

        } 
        //System.out.println((count+1)); 
        return count+1 ; 
      } 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/152551.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号