我在双向链表中实现选择排序。 我必须通过查找最小元素并将其插入列表的开头来按姓氏对列表进行排序。 但是有一些麻烦,当我运行我的程序时,我在循环中的Sort Method中有NIL异常。 它是整个应用程序,因此您可以编译它并运行,如果您愿意。 帮助将不胜感激。 感谢。
public class LinkedList {
public Node first;
public Node last;
public LinkedList() {
first = null;
last = null;
}
public void addFirst(Student student) {
Node f = first;
Node newNode = new Node(student);
first = newNode;
if (f == null) last = newNode;
else {
f.previous = newNode;
newNode.next = f;
}
}
public void addLast(Student student) {
Node l = last;
Node newNode = new Node(student);
last = newNode;
if (l == null) first = newNode;
else {
l.next = newNode;
newNode.previous = l;
}
}
public void display() {
Node current = first;
while (current != null) {
System.out.print(current.student.name + "\b");
System.out.print(current.student.surname + "\b");
System.out.println(current.student.educationType);
current = current.next;
}
}
public Node findSmallest(Node startNode) {
Node smallest = startNode;
while (startNode.next != null) {
if (smallest.student.surname.compareToIgnoreCase(startNode.next.student.surname) > 1)
smallest = startNode.next;
else startNode = startNode.next;
}
return smallest;
}
public void Sort() {
LinkedList newList = new LinkedList();
Node current = first;
while (current.next != null) {
Node smallest = findSmallest(current);
newList.addLast(smallest.student);
delNode(smallest);
current = current.next;
}
first = newList.first;
last = newList.last;
}
public void delNode(Node toDel) {
if (toDel.previous == null) {
toDel.next.previous = null;
first = toDel.next;
return;
}
if (toDel.next == null) {
toDel.previous.next = null;
last = toDel.previous;
return;
}
toDel.previous.next = toDel.next;
toDel.next.previous = toDel.previous;
}
}
public class Student {
public String name;
public String surname;
public String educationType;
static public Student createStudent() {
Student student = new Student();
try {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
System.out.println("Enter student's name:");
student.name = br.readLine();
System.out.println("Enter surname:");
student.surname = br.readLine();
System.out.println("Enter educational type:");
student.educationType = br.readLine();
} catch (IOException e) {
throw new NotImplementedException();
}
return student;
}
}
public class Node {
public Student student;
public Node next;
public Node previous;
public Node(Student student) {
this.student = student;
}
}
答案 0 :(得分:1)
我没有运行它,所以只是查看你的代码:
这不是真正的选择排序,因为您正在构建新列表而不是对旧列表进行排序。
对于单个元素列表,delNode()将因NPE而失败,所以也许这就是错误的(如果你要删除最后一个元素,它也会失败)。
除非你不被允许,否则请使用哨兵。