链表的Java实现



我正试图在java中实现一个链表,查阅我学校的课本。

为了查看列表,我对每个节点使用方法getInfo(),该方法应该返回列表中每个人的姓名(我正在实现一个人员列表(。

我不明白为什么我的教科书在类Node的方法getInfo()中返回一个new Invitato(info),而不是存储在类Nodo中的那个。

如果我试图返回存储在类Nodo中的那个,我会得到一个空指针异常。

public class Main{
public static void main(String args[]){

Invitato i1 = new Invitato("Michele","Bianchi");
Invitato i2 = new Invitato("Paolo","Rossi");
Invitato i3 = new Invitato("Mario","Verdi");
Invitato i4 = new Invitato("Giacomo","Neri");
Lista l = new Lista();
l.inserisciInCoda(i1);
l.inserisciInTesta(i2);
l.inserisciInTesta(i3);
l.inserisciInPosizione(i4,2);
l.visitaLista();
}
}

public class Lista{
private Nodo head;
private int elementi;
public Lista(){
elementi=0;
head = null;
}
private Nodo creaNodo(Invitato invitato, Nodo link){
Nodo nuovoNodo = new Nodo(invitato);
nuovoNodo.setLink(link);
return nuovoNodo;
}
public int getElementi(){
return elementi;
}
private Nodo getLinkPosizione(int n){
Nodo p = head; 
int i = 1;
if(n>elementi || n<1)
return null;
else{
while(p.getLink() != null && i<n){
p = p.getLink();
i++;
}
}
return p;
}
public void visitaLista(){
Nodo p = head;
if(p==null){
System.out.println("Lista vuota");
}
else{
while(p!=null){
System.out.println(p.getInfo().toString());
p = p.getLink();
}
}
}
public void inserisciInTesta(Invitato invitato){
Nodo p = creaNodo(invitato, head);      //creo un nuovo nodo e lo liko alla testa
head = p;                             //il nuovo nodo diventa la head
elementi++;
}
public void inserisciInCoda(Invitato invitato){
if(head==null){                             //se la lista è vuota
inserisciInTesta(invitato);          //posso inserire il nuovo nodo in testa
}
else{
Nodo p = getLinkPosizione(elementi);            //prendo l'ultimo nodo
Nodo nuovoNodo = creaNodo(invitato, null);
p.setLink(nuovoNodo);
elementi++;
}
}
public void inserisciInPosizione(Invitato invitato, int posizione){
if(posizione <=1){
inserisciInTesta(invitato);
}
else{
if(posizione > elementi){
inserisciInCoda(invitato);
}
else{
Nodo p = getLinkPosizione(posizione-1);
Nodo nuovoNodo = creaNodo(invitato,p.getLink());
p.setLink(nuovoNodo);
elementi++;
}
}
}
public void eliminaInTesta(){
if(head == null)    //la lista è vuota?
return;
head = head.getLink(); //la nuova head è il nodo a cui linka, quindi ora head riferisce al secondo nodo
elementi--;
}
public void eliminaInCoda(){
if(head == null){               //lista vuota
return;
}
Nodo p = getLinkPosizione(elementi-1);    //prendo il penultimo nodo
p.setLink(null);                // e metto il suo link a null
elementi--;
}
public void eliminaInPosizione(int n){
if(n<=1){
this.eliminaInTesta();
}
else{
if(n>=elementi){
this.eliminaInCoda();
}
else{
Nodo pp = getLinkPosizione(n-1);         //nodo prima di quello da cancellare
Nodo ps = getLinkPosizione(n);          //nodo da cancellare

pp.setLink(ps.getLink());                //assegno al link precedente a quello da cancellare il link di quello che sto cancellando
elementi--;
}
}
}
}
public class Invitato{
private String nome;
private String cognome; 
public Invitato(String nome, String cognome){
this.nome = nome;
this.cognome = cognome;
}
public Invitato(Invitato invitato){
this.nome = invitato.getNome();
this.cognome = invitato.getCognome();
}
public String getNome(){
return nome;
}
public String getCognome(){
return cognome; 
}
public String toString(){
return nome + " " + cognome+";";
}
}
public class Nodo{
private Invitato info; 
private Nodo link;
public Nodo(Invitato invitato){
this.invitato = new Invitato(invitato);
link = null;
}
public Invitato getInfo(){
return new Invitato(info);
}
public void setLink(Nodo link){
this.link = link;
}
public Nodo getLink(){
return link;
}    
}

Nodo的构造函数不正确:
this.invitato = new Invitato(invitato);
应为:
this.info= new Invitato(invitato);

并且您不需要在Nodo的构造函数和getInfo方法中构建Invitato的新实例:

public Nodo(Invitato invitato){
this.info = invitato;
link = null;
}
public Invitato getInfo(){
return info;
}

一旦构造函数修复,我就得到了一个没有任何异常的列表:

Mario Verdi;
Giacomo Neri;
Paolo Rossi;
Michele Bianchi;

相关内容

  • 没有找到相关文章

最新更新