首页 > 编程语言 >Java泛型链表实现

Java泛型链表实现

时间:2022-12-14 15:06:21浏览次数:56  
标签:head Java cur next 链表 泛型 Entry null public


​​链表简介​​

代码实现

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;
}


标签:head,Java,cur,next,链表,泛型,Entry,null,public
From: https://blog.51cto.com/u_12938555/5936977

相关文章

  • 15-咸鱼学Java-内部类
    实例内部类实例内部类简而言之就是类里面嵌入着类,就像环套环一样Demo:classOuterClass2//外部类{privateinta=1000;publicOuterClass2(){Sy......
  • LeetCode-Java-559. Maximum Depth of N-ary Tree
    题目Givenan-arytree,finditsmaximumdepth.Themaximumdepthisthenumberofnodesalongthelongestpathfromtherootnodedowntothefarthestleafnode......
  • 14-咸鱼学Java-面向对象基础:类
    类类就相当于自定义类型,有自己的数据域,有自己的方法。属于一种用户自定义类型。类的目的就是模拟现实中存在的物体,如一个Person类,一个人他有自己的名字,年龄,性别等等,他有自己......
  • 17-咸鱼学Java-内部类实际应用-Java链表
    ​​内部类​​,​​未使用内部类的链表​​可以点击名字查看。此篇文章主要介绍运用内部类的Java链表的写法。链表正如其名,就像一个一个珠子被串起来,只有前一个珠子和......
  • LeetCode-Java-876. Middle of the Linked List
    题目Givenanon-empty,singlylinkedlistwithheadnodehead,returnamiddlenodeoflinkedlist.Iftherearetwomiddlenodes,returnthesecondmiddlenode.......
  • 咸鱼学Java-多线程基础
    实现多线程的方法1.继承Thread,并且重写run方法(线程体)2.实现Runnable接口,实现run方法(线程体)必须重写run1.继承ThreadclassMyThreadextendsThread{publicMyThr......
  • 剑指Offer-Java-用两个栈实现队列
    题目用两个栈来实现一个队列,完成队列的Push和Pop操作。队列中的元素为int类型。代码只需要来回倒就可以实现了。importjava.util.Stack;publicclassSolution{Stack......
  • 23-咸鱼学Java-Java中的栈
    栈的图示代码/***栈*@author焦焱**/publicclassStack{/***栈顶标记*/inttop;/***栈内元素*/int[]elem;/**......
  • LeetCode-Java-893. Groups of Special-Equivalent Strings
    题目YouaregivenanarrayAofstrings.TwostringsSandTarespecial-equivalentifafteranynumberofmoves,S==T.Amoveconsistsofchoosingtwoindices......
  • 能让Java开发者提高效率的10个工具
    ​ Java受到全球百万计开发者的追捧,已经演变为一门出色的编程语言。最终,这门语言随着技术的变化,不断的被改善以迎合变化的市场需求。无论你是否拥有一家科技公司,软件已经......