随笔-48  评论-26  文章-0  trackbacks-0
import java.util.ArrayList;
import java.util.List;
  
  
/** *//**
   * 链表实现ADT
   * 
@author BruceLeey
   
*/
  
class Node {
 
     Object obj;  
//数值域
     Node next; //链域
 
     
public Node() {
     }
 
     
public Node(Object value) {
 
         
this.obj = value;
         next 
= null;
     }
 }
 
 
class LinkList {
 
     
private Node first;  //头节点,不记录在链表之内
     private int size;  //记录链表节点长度
 
     
public LinkList() {
 
         first 
= null;
         size 
= 0;
 
     }
 
     
/** *//**
      * 添加节点
      *
      * 
@param value
      
*/
     
public void addNode(Object value) {
         System.out.println(
"\n-------------------------添加节点 " + value + " -------------------------");
        Node currentNode 
= new Node(value);
        currentNode.next 
= first; //当前节点链域指向头节点
         first = currentNode;        //头节点记录当前节点地址
         size++;
     }
 
     
/** *//**
      * 验证是否为空
      * 
@return
      
*/
     
public boolean isEmpty() {
         
return size == 0;
     }
 
     
/** *//**
      * 删除表头
     * 
@param value
     
*/
     
public Node removeFirstNode() {
         System.out.println(
"\n-------------------------移除头节点-------------------------");
         Node temp 
= first;
         first 
= first.next;   //指向下一节点
         size--;
         System.out.println(
"\n移除的表头数据为: " + temp.obj);
         
return temp;   //返回删除的节点
     }
 
     
/** *//**
      * 封装长度
      * 
@return
      
*/
     
public int getSize() {
 
        
return size;
     }
 
     
/** *//**
     * 找出索引之前的节点
      * 
@param index
      * 
@return
      
*/
     
public List<Node> getNodeByIndex(int index) {
         System.out.println(
"\n-------------------------查找" + index + "之前的所有节点-------------------------");
         List
<Node> list = new ArrayList<Node>();
         
assert (!(index > getSize() - 1 || index < 0));
         Node current 
= first;   //定位到头节点
         for (int i = 0; i < index; i++) {
             list.add(current);
             current 
= current.next;   //以此往下移
       }
         
for (int j = 0; j < list.size(); j++) {
            System.out.println(
"\n查找到的数据为:  " + list.get(j).obj);
         }
         
return list;
     }
 
     
/** *//**
     * 输出链表
     
*/
    
public void displayNode() {
        System.out.println(
"\n-------------------------开始输出链表-------------------------");
        
assert (!this.isEmpty());
        Node current 
= first;
        
for (int i = 0; i < getSize(); i++) {

            System.out.println(
"节点为: " + current.obj.toString());
            current 
= current.next;
        }

    }
}


public class TestAdt {

    
public static void main(String[] args) {
        LinkList link 
= new LinkList();
        
for (int i = 0; i < 10; i++) {
            link.addNode(
"我是节点 " + i);
        }
        link.displayNode();
        Node node 
= link.removeFirstNode();
        link.displayNode();
        link.getNodeByIndex(
5);
        link.displayNode();

    }
}
posted on 2009-09-26 14:38 Worker 阅读(211) 评论(0)  编辑  收藏 所属分类: 算法/数据结构

只有注册用户登录后才能发表评论。


网站导航: