首先我们定义链表的结构,期中有两个公有成员,分别储存数据和下一个结点对象的引用。代码如下:

import java.util.Scanner;//测试时需要输入数据。
class Lnode//定义链表的结构
{
 public int data;//结点的数据域。
 public Lnode next;//下一个结点对象的引用。
 public Lnode(int data)
 {
  this.data=data;
 }
}
import java.util.Scanner;//测试时需要输入数据。
class Lnode//定义链表的结构
{
 public int data;//结点的数据域。
 public Lnode next;//下一个结点对象的引用。
 public Lnode(int data)
 {
  this.data=data;
 }
}

接下来我们开始写链表的常用的操作函数。其中有个错误,已经标注出来,希望大家给我提示一下。代码如下:

class Linklist//此类包含操作链表的一些方法;
{
 public Lnode currentadd;//插入时将用到该元素;
 public Lnode head;//头结点
 public Lnode current;//始终指向当前操作的结点
 public void addListinsert(int data)//输入一个元素,将插入链表的后面,如果链表为空将构建链表。
 {
  if(head==null)//判断表头是否为空
  {
   head=new Lnode(data);
   current=head;
  }
  else
  {//如果已经存在头结点,创建新的结点,放在前结点的后面。
   current.next=new Lnode(data);
   current=current.next;
  }
 }
 public void PrintTraverse()//用于输出所有的元素值。
 {//用于输出所有的元素
  if(head==null)
  {//判断链表的头是否为空,如果为空说明链表不存在。
   return;
  }
  else
  {
   current=head;//如果链表不为空,则将current引用(相当于指针的指向)头结点。
   while(current!=null)//遍历整个链表。
   {
    System.out.print(current.data+" ");
    current=current.next;
   }
  }
  System.out.println();//为了方便显示,每次输出完毕后换行。
 }
 public void Listdelete(int n)//输入要删除元素的位序,用于删除操作。
 { 
     int i=1;//i为计数器,始终为current所引用的元素。
      current=head;
   if(n==1)//首先判断是不是头结点,如果是需要修改head的指向。
  { 
   current=head.next;head=head.next;
  }
  else{//如果不是头结点,首先找到n-1个元素,让n-1元素的next指向n+1。
   while(current!=null&&i<n-1)
   {
    ++i;current=current.next;
   }
   current.next=current.next.next;
  }
 }
 public int LocateElem(int data)//查找与传入数据相同的元素。
 {
  int i=0;
  current=head;
  while(current!=null)//遍历整个链表
  { i++;
   if(current.data==data)break;//如果找到相同的元素则跳出循环,结束遍历。
   current=current.next;
  }
  return i;
 }
 public int ListLength()//测试链表的长度
 { 
  int i=0;//i为计数器.
  current=head;
  while(current!=null)//遍历链表。
  {
   i++; current=current.next;
  }
  return i;
 }
 
 public void Listinsert(int n,int data)//在第n个元素之前插入数据data;
 {
  int i=1;
  current=head;                //注意这个函数存在错误,本人还没有发现为什么错。
  if(n==1)
  {                            //假如在第3个元素之前插入数据,它直接将第三个元素的值修改
   current=new Lnode(data);
   current.next=head;           //错误!!!!注意//请大家帮忙指正。万分感谢》。
   head=current;                //只有在第一个元素之前插入才正确。
  }
  else
  {
   while(current!=null&&i<n-1)         //*****************************   
   {                                    //**此插入函数存在错误。
    current=current.next;
    i++;                                //***********************

   }
   currentadd=new Lnode(data);         //请大家看到给我指正。我会明天在自己看看,可能自己绕圈出不来了
   currentadd.next=current.next.next;
   current.next=currentadd;
  }
 }
}
class Linklist//此类包含操作链表的一些方法;
{
 public Lnode currentadd;//插入时将用到该元素;
 public Lnode head;//头结点
 public Lnode current;//始终指向当前操作的结点
 public void addListinsert(int data)//输入一个元素,将插入链表的后面,如果链表为空将构建链表。
 {
  if(head==null)//判断表头是否为空
  {
   head=new Lnode(data);
   current=head;
  }
  else
  {//如果已经存在头结点,创建新的结点,放在前结点的后面。
   current.next=new Lnode(data);
   current=current.next;
  }
 }
 public void PrintTraverse()//用于输出所有的元素值。
 {//用于输出所有的元素
  if(head==null)
  {//判断链表的头是否为空,如果为空说明链表不存在。
   return;
  }
  else
  {
   current=head;//如果链表不为空,则将current引用(相当于指针的指向)头结点。
   while(current!=null)//遍历整个链表。
   {
    System.out.print(current.data+" ");
    current=current.next;
   }
  }
  System.out.println();//为了方便显示,每次输出完毕后换行。
 }
 public void Listdelete(int n)//输入要删除元素的位序,用于删除操作。
 { 
     int i=1;//i为计数器,始终为current所引用的元素。
      current=head;
   if(n==1)//首先判断是不是头结点,如果是需要修改head的指向。
  { 
   current=head.next;head=head.next;
  }
  else{//如果不是头结点,首先找到n-1个元素,让n-1元素的next指向n+1。
   while(current!=null&&i<n-1)
   {
    ++i;current=current.next;
   }
   current.next=current.next.next;
  }
 }
 public int LocateElem(int data)//查找与传入数据相同的元素。
 {
  int i=0;
  current=head;
  while(current!=null)//遍历整个链表
  { i++;
   if(current.data==data)break;//如果找到相同的元素则跳出循环,结束遍历。
   current=current.next;
  }
  return i;
 }
 public int ListLength()//测试链表的长度
 { 
  int i=0;//i为计数器.
  current=head;
  while(current!=null)//遍历链表。
  {
   i++; current=current.next;
  }
  return i;
 }
 
 public void Listinsert(int n,int data)//在第n个元素之前插入数据data;
 {
  int i=1;
  current=head;                //注意这个函数存在错误,本人还没有发现为什么错。
  if(n==1)
  {                            //假如在第3个元素之前插入数据,它直接将第三个元素的值修改
   current=new Lnode(data);
   current.next=head;           //错误!!!!注意//请大家帮忙指正。万分感谢》。
   head=current;                //只有在第一个元素之前插入才正确。
  }
  else
  {
   while(current!=null&&i<n-1)         //*****************************   
   {                                    //**此插入函数存在错误。
    current=current.next;
    i++;                                //***********************

   }
   currentadd=new Lnode(data);         //请大家看到给我指正。我会明天在自己看看,可能自己绕圈出不来了
   currentadd.next=current.next.next;
   current.next=currentadd;
  }
 }
}

接下来是测试函数,最后一个插入数据的函数存在错误 所以我选择在第一个元素之前插入数据,这样是没错的。只有在第一个之前插入没事。输入的数据为11,12,13,14,15,16,17代码如下:

public class Test {
  public static void main(String[] args)
  {
   String str;
   int data,n;
   Scanner sc=new Scanner(System.in);
   Linklist link=new Linklist();
   System.out.println("如果想插入元素请按Y,输入完毕请按N");
   str=sc.next();
   while(str.equals("Y"))
   {
    System.out.println("请输入整形数据");
    data=sc.nextInt();
    link.addListinsert(data);
    System.out.println("如果想继续插入元素请按Y,输入完毕请按N");
    str=sc.next();
   }
   System.out.print("链表的所有元素为:");
   link.PrintTraverse();
   System.out.print("请输入要删除的元素的位序: ");
   n=sc.nextInt();
   link.Listdelete(n);
   System.out.print("删除后链表的所有元素为:");
   link.PrintTraverse();
   System.out.print("链表的长度为:"+link.ListLength()+"\n"+"你想在第几个元素之前插入:");
   n=sc.nextInt();
   System.out.print("请输入要插入的数据:");
   data=sc.nextInt();
   link.Listinsert(n, data);
   System.out.print("插入后链表的所有元素为:");
   link.PrintTraverse();
   System.out.println("请输入你要查找的元素,将返回其位序");
   data=sc.nextInt();
   System.out.print("该元素的位序为:"+link.LocateElem(data));
  }
}
 public class Test {
  public static void main(String[] args)
  {
   String str;
   int data,n;
   Scanner sc=new Scanner(System.in);
   Linklist link=new Linklist();
   System.out.println("如果想插入元素请按Y,输入完毕请按N");
   str=sc.next();
   while(str.equals("Y"))
   {
    System.out.println("请输入整形数据");
    data=sc.nextInt();
    link.addListinsert(data);
    System.out.println("如果想继续插入元素请按Y,输入完毕请按N");
    str=sc.next();
   }
   System.out.print("链表的所有元素为:");
   link.PrintTraverse();
   System.out.print("请输入要删除的元素的位序: ");
   n=sc.nextInt();
   link.Listdelete(n);
   System.out.print("删除后链表的所有元素为:");
   link.PrintTraverse();
   System.out.print("链表的长度为:"+link.ListLength()+"\n"+"你想在第几个元素之前插入:");
   n=sc.nextInt();
   System.out.print("请输入要插入的数据:");
   data=sc.nextInt();
   link.Listinsert(n, data);
   System.out.print("插入后链表的所有元素为:");
   link.PrintTraverse();
   System.out.println("请输入你要查找的元素,将返回其位序");
   data=sc.nextInt();
   System.out.print("该元素的位序为:"+link.LocateElem(data));
  }
}

运行结果为:(注意:输入的数据为11,12,13,14,15,16,17)

-------------------------------------华丽分割线-------------------------------------------------

学习数据结构后突然想用java实现链表,但是java学了很长时间了,都快忘干净了,很多用词不当的给我指正。谢谢大家。