Java泛型链表实现

链表简介

代码实现

package com.chenxixuexi;
/**
 * 泛型链表
 * 单链表逆置数据--节点
 * 求单链表倒数第K节点
 * 求两个单链表 是否相交  相交交点
 * 判断单链表是否有环?有求出环的入口点  求环的长度?
 * 合并两个递增的单链表
 * @author 14831
 *
 * @param <T>
 */
public class Link<T> {
    private Entry<T> head = new Entry<T>(); //指向头结点的引用


    /**
     * 节点类
     * @author 14831
     *
     * @param <T> 类型
     */
    class Entry<T>{//Entry  Node
        T data;
        Entry<T> next;
        /**
         * 头结点空构造方法
         */
        public Entry() {
            data = null;
            next = null;
        }
        /**
         * 构造节点
         * @param a
         */
        public Entry(T a) {
            data = a;
            next = null;
        }
    }

    /**
     * 头插法
     * @param val 需要插入的数据
     */
    public void insertHead(T val)
    {
        //有这么一个节点
        Entry<T> cur = new Entry<T>(val);
        cur.next = head.next;
        head.next = cur;
    }

    /**
     * 尾插法
     * @param val 需要插入的值
     */
    public void insertTail(T val)
    {
        Entry<T> cur = head;
        while(cur.next!= null)  //循环直到cur.next为空  把cur弹出
        {
            cur = cur.next;
        }
        cur.next = new Entry<T>(val);//给cur.next 赋值为新节点的地址

    }
    /**
     * 插入到pos位置 从有数据开始为0下标
     * @param pos   位置序号
     * @param val   插入的值
     */
    public void insertPos(int pos,T val)
    {
        Entry<T> cur = head;    //获取头结点
        int count = 0;
        if(pos<0||pos>getLength())  //如果需要中断操作,只需要在此return即可
        System.out.println("下标"+pos+"不合法,自动插入到最后位置");
        while(cur.next!= null)  //循环直到cur.next为空  把cur弹出 及如果没找到就会把元素插入到最后面
        {

            if(count == pos)
                break;

            count++;

            cur = cur.next;
        }
        Entry<T> cur1 = new Entry<T>(val);
        cur1.next = cur.next;
        cur.next = cur1;
    }




    /**
     * 遍历输出数组
     */
    public void show()
    {
        Entry<T> cur = head.next;   //获取到第一个节点
        System.out.print("[");  
        while(cur!=null)            //如果cur不是null
        {       
            System.out.print(cur.data+" "); //输出
            cur = cur.next;         //向下递进
        }
        System.out.println("]");
    }
    /**
     * 获得链表长度
     * @return 链表长度
     */
    public int getLength()
    {   int count=0;
        Entry<T> cur = head.next;   //获取到第一个节点
        while(cur!=null)            //如果cur不是null
        {       
            count++;                //计数
            cur = cur.next;         //向下递进
        }
        return count;
    }
        /**
     * 翻转链表
     */
    public void Reversal()
    { 
            Entry<T> p = head.next,p1 = null,p2 = null;  
            while(p!=null){  
                p1 = p.next;                //设置p1是p结点的后继结点,即用p1来保持p的后继结点  
                p.next = p2;                //链接,使p.next指向p结点的前一个结点  
                p2 = p;                     //p2向后移一步  
                p = p1;                     //p向后移一步  
            }  
            head.next = p2;                 //head.next指向最后一个结点
    }

    /**
     * 求倒数第K个元素
     * 
     * @param k 序号
     * @return 所求元素
     */
    public T BackWardsToK(int k)
    {
        if(k>getLength()-1){        //判错
        System.err.println("超越限制,下标不合法,倒数下标从0开始");
        return null;
        }
        int key = getLength()-k;
        Entry<T> cur = head;    //获取头结点
        int count = 0;
        while(cur.next!= null)  //循环直到cur.next为空  把cur弹出 及如果没找到就会把元素插入到最后面
        {

            if(count == key)    
                break;
            count++;
            cur = cur.next;
        }


        return cur.data;
    }
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值