选择排序链表
Selection Sorting a Linked List
对于我的数据结构 class 中的作业,我得到了一个包含整数的链表的节点。老是报空指针异常,可是我盯着看太久了,怎么也找不到哪里搞错了
这是我的排序class:
public class Sorter {
public Sorter() {
}
/*****
* Sorter
* takes a linked list, sorts it
* @param head linked list to sort
* @return sorted linked list
*/
public IntNode nodeSort(IntNode head) {
IntNode holderHead = new IntNode(-1, null);
IntNode cursor;
int currentMax = -1;
int count = 0;
while (count < head.listLength(head)) {
IntNode tempHead = new IntNode(-1, null);
for (cursor = head.getLink(); cursor.getLink() != null; cursor = cursor.getLink()) {
if (currentMax > cursor.getLink().getData()) {
tempHead.setLink(cursor.getLink());
}
}
if (count == 0) {
holderHead.setLink(tempHead.getLink());
} else {
tempHead.getLink().setLink(holderHead);
holderHead.setLink(null);
holderHead = tempHead.getLink();
}
count+=1;
}
return holderHead;
}
这是 IntNode class(由我的导师提供):
public class IntNode {
private int data;
private IntNode link;
public IntNode(int initialData, IntNode initialLink) {
data = initialData;
link = initialLink;
}
public void addAfter(int item) {
link = new IntNode(item, link);
}
public int getData( ) {
return data;
}
public IntNode getLink( ) {
return link;
}
public static IntNode listCopy(IntNode source) {
IntNode copyHead;
IntNode copyTail;
if (source == null)
return null;
copyHead = new IntNode(source.data, null);
copyTail = copyHead;
while (source.link != null)
{
source = source.link;
copyTail.addAfter(source.data);
copyTail = copyTail.link;
}
return copyHead;
}
public static IntNode[ ] listCopyWithTail(IntNode source) {
IntNode copyHead;
IntNode copyTail;
IntNode[ ] answer = new IntNode[2];
if (source == null)
return answer;
copyHead = new IntNode(source.data, null);
copyTail = copyHead;
while (source.link != null)
{
source = source.link;
copyTail.addAfter(source.data);
copyTail = copyTail.link;
}
answer[0] = copyHead;
answer[1] = copyTail;
return answer;
}
public static int listLength(IntNode head) {
IntNode cursor;
int answer;
answer = 0;
for (cursor = head; cursor != null; cursor = cursor.link)
answer++;
return answer;
}
public static IntNode[ ] listPart(IntNode start, IntNode end) {
IntNode copyHead;
IntNode copyTail;
IntNode cursor;
IntNode[ ] answer = new IntNode[2];
copyHead = new IntNode(start.data, null);
copyTail = copyHead;
cursor = start;
while (cursor != end)
{
cursor = cursor.link;
if (cursor == null)
throw new IllegalArgumentException
("end node was not found on the list");
copyTail.addAfter(cursor.data);
copyTail = copyTail.link;
}
answer[0] = copyHead;
answer[1] = copyTail;
return answer;
}
public static IntNode listPosition(IntNode head, int position) {
IntNode cursor;
int i;
if (position <= 0)
throw new IllegalArgumentException("position is not positive");
cursor = head;
for (i = 1; (i < position) && (cursor != null); i++)
cursor = cursor.link;
return cursor;
}
public static IntNode listSearch(IntNode head, int target) {
IntNode cursor;
for (cursor = head; cursor != null; cursor = cursor.link)
if (target == cursor.data)
return cursor;
return null;
}
public void removeNodeAfter( ) {
link = link.link;
}
public void setData(int newData)
{
data = newData;
}
public void setLink(IntNode newLink) {
link = newLink;
}
}
Driver Class:
public class Driver {
public static void main(String args[]) {
IntNode head = new IntNode(-1, null);
Sorter sorter = new Sorter();
head.addAfter(2);
head.addAfter(4);
head.addAfter(5);
head.addAfter(3);
head.addAfter(6);
head.addAfter(9);
head.addAfter(8);
head.addAfter(10);
head.setLink(sorter.nodeSort(head));
for (IntNode i = head; i != null; i = i.getLink()) {
System.out.println(i.getData());
}
}
}
问题出在你的排序方法上。我为您提供了一个基于您的数据结构的实现。希望这有助于...
public void selectionSort(IntNode head) {
for (IntNode node1 = head; node1 != null; node1 = node1.getLink()) {
IntNode min = node1;
for (IntNode node2 = node1; node2 != null; node2 = node2.getLink()) {
if (min.getData() > node2.getData()) {
min = node2;
}
}
IntNode temp = new IntNode(node1.getData(), null);
node1.setData(min.getData());
min.setData(temp.getData());
}
}
而且您不需要 return 头节点,因此您的主要方法可以如下所示:
public static void main(String args[]) {
IntNode head = new IntNode(-1, null);
Sorter sorter = new Sorter();
head.addAfter(4);
head.addAfter(5);
head.addAfter(2);
head.addAfter(3);
head.addAfter(6);
head.addAfter(9);
head.addAfter(8);
head.addAfter(10);
sorter.selectionSort(head);
for (IntNode i = head; i != null; i = i.getLink()) {
System.out.println(i.getData());
}
}
对于我的数据结构 class 中的作业,我得到了一个包含整数的链表的节点。老是报空指针异常,可是我盯着看太久了,怎么也找不到哪里搞错了
这是我的排序class:
public class Sorter {
public Sorter() {
}
/*****
* Sorter
* takes a linked list, sorts it
* @param head linked list to sort
* @return sorted linked list
*/
public IntNode nodeSort(IntNode head) {
IntNode holderHead = new IntNode(-1, null);
IntNode cursor;
int currentMax = -1;
int count = 0;
while (count < head.listLength(head)) {
IntNode tempHead = new IntNode(-1, null);
for (cursor = head.getLink(); cursor.getLink() != null; cursor = cursor.getLink()) {
if (currentMax > cursor.getLink().getData()) {
tempHead.setLink(cursor.getLink());
}
}
if (count == 0) {
holderHead.setLink(tempHead.getLink());
} else {
tempHead.getLink().setLink(holderHead);
holderHead.setLink(null);
holderHead = tempHead.getLink();
}
count+=1;
}
return holderHead;
}
这是 IntNode class(由我的导师提供):
public class IntNode {
private int data;
private IntNode link;
public IntNode(int initialData, IntNode initialLink) {
data = initialData;
link = initialLink;
}
public void addAfter(int item) {
link = new IntNode(item, link);
}
public int getData( ) {
return data;
}
public IntNode getLink( ) {
return link;
}
public static IntNode listCopy(IntNode source) {
IntNode copyHead;
IntNode copyTail;
if (source == null)
return null;
copyHead = new IntNode(source.data, null);
copyTail = copyHead;
while (source.link != null)
{
source = source.link;
copyTail.addAfter(source.data);
copyTail = copyTail.link;
}
return copyHead;
}
public static IntNode[ ] listCopyWithTail(IntNode source) {
IntNode copyHead;
IntNode copyTail;
IntNode[ ] answer = new IntNode[2];
if (source == null)
return answer;
copyHead = new IntNode(source.data, null);
copyTail = copyHead;
while (source.link != null)
{
source = source.link;
copyTail.addAfter(source.data);
copyTail = copyTail.link;
}
answer[0] = copyHead;
answer[1] = copyTail;
return answer;
}
public static int listLength(IntNode head) {
IntNode cursor;
int answer;
answer = 0;
for (cursor = head; cursor != null; cursor = cursor.link)
answer++;
return answer;
}
public static IntNode[ ] listPart(IntNode start, IntNode end) {
IntNode copyHead;
IntNode copyTail;
IntNode cursor;
IntNode[ ] answer = new IntNode[2];
copyHead = new IntNode(start.data, null);
copyTail = copyHead;
cursor = start;
while (cursor != end)
{
cursor = cursor.link;
if (cursor == null)
throw new IllegalArgumentException
("end node was not found on the list");
copyTail.addAfter(cursor.data);
copyTail = copyTail.link;
}
answer[0] = copyHead;
answer[1] = copyTail;
return answer;
}
public static IntNode listPosition(IntNode head, int position) {
IntNode cursor;
int i;
if (position <= 0)
throw new IllegalArgumentException("position is not positive");
cursor = head;
for (i = 1; (i < position) && (cursor != null); i++)
cursor = cursor.link;
return cursor;
}
public static IntNode listSearch(IntNode head, int target) {
IntNode cursor;
for (cursor = head; cursor != null; cursor = cursor.link)
if (target == cursor.data)
return cursor;
return null;
}
public void removeNodeAfter( ) {
link = link.link;
}
public void setData(int newData)
{
data = newData;
}
public void setLink(IntNode newLink) {
link = newLink;
}
}
Driver Class:
public class Driver {
public static void main(String args[]) {
IntNode head = new IntNode(-1, null);
Sorter sorter = new Sorter();
head.addAfter(2);
head.addAfter(4);
head.addAfter(5);
head.addAfter(3);
head.addAfter(6);
head.addAfter(9);
head.addAfter(8);
head.addAfter(10);
head.setLink(sorter.nodeSort(head));
for (IntNode i = head; i != null; i = i.getLink()) {
System.out.println(i.getData());
}
}
}
问题出在你的排序方法上。我为您提供了一个基于您的数据结构的实现。希望这有助于...
public void selectionSort(IntNode head) {
for (IntNode node1 = head; node1 != null; node1 = node1.getLink()) {
IntNode min = node1;
for (IntNode node2 = node1; node2 != null; node2 = node2.getLink()) {
if (min.getData() > node2.getData()) {
min = node2;
}
}
IntNode temp = new IntNode(node1.getData(), null);
node1.setData(min.getData());
min.setData(temp.getData());
}
}
而且您不需要 return 头节点,因此您的主要方法可以如下所示:
public static void main(String args[]) {
IntNode head = new IntNode(-1, null);
Sorter sorter = new Sorter();
head.addAfter(4);
head.addAfter(5);
head.addAfter(2);
head.addAfter(3);
head.addAfter(6);
head.addAfter(9);
head.addAfter(8);
head.addAfter(10);
sorter.selectionSort(head);
for (IntNode i = head; i != null; i = i.getLink()) {
System.out.println(i.getData());
}
}