我正在編寫一個賦值的代碼,該賦值需要一個方法來顛倒LinkedList中的元素,並給定要反轉的列表部分。例如,如果用戶輸入3,該方法會顛倒數組中的前3個元素。我爲它編寫了代碼,但不是顛倒代碼,而是簡單地用第一個索引中的元素替換第二個元素。我唯一的問題似乎是reverseFirstSome方法。我並不是要求你爲我編寫代碼,但任何指向正確方向的指針都將不勝感激。這裏是我的類全碼:顛倒鏈表中的對象的問題
import java.util.NoSuchElementException;
public class LinkedList
{
//nested class to represent a node
private class Node
{
public Object data;
public Node next;
}
//only instance variable that points to the first node.
private Node first;
// Constructs an empty linked list.
public LinkedList()
{
first = null;
}
// Returns the first element in the linked list.
public Object getFirst()
{
if (first == null)
{
NoSuchElementException ex
= new NoSuchElementException();
throw ex;
}
else
return first.data;
}
// Removes the first element in the linked list.
public Object removeFirst()
{
if (first == null)
{
NoSuchElementException ex = new NoSuchElementException();
throw ex;
}
else
{
Object element = first.data;
first = first.next; //change the reference since it's removed.
return element;
}
}
// Adds an element to the front of the linked list.
public void addFirst(Object element)
{
//create a new node
Node newNode = new Node();
newNode.data = element;
newNode.next = first;
//change the first reference to the new node.
first = newNode;
}
// Returns an iterator for iterating through this list.
public ListIterator listIterator()
{
return new LinkedListIterator();
}
public String toString() {
LinkedListIterator iterator = new LinkedListIterator();
String result = "{ ";
while (iterator.hasNext())
result += (iterator.next() + " ");
result += "}\n";
return result;
}
public int size(){
LinkedListIterator iterator = new LinkedListIterator();
int a = 0;
while (iterator.hasNext()){
iterator.next();
a++;
}
return a;
}
public void addElement(Object obj, int index){
if (index < 0 || index > size()){
IndexOutOfBoundsException ex = new IndexOutOfBoundsException();
throw ex;
}
LinkedListIterator iterator = new LinkedListIterator();
for(int i = 0; i < index; i++){
if (iterator.hasNext()){
iterator.next();
}else{
NoSuchElementException ex = new NoSuchElementException();
throw ex;
}
}
if (iterator.hasNext()){
Object a = iterator.next();
iterator.set(obj);
while(iterator.hasNext()){
Object b = iterator.next();
iterator.set(a);
a = b;
}
iterator.add(a);
}
else
iterator.add(obj);
}
public Object getElement(int index)
{
LinkedListIterator it = new LinkedListIterator();
for(int i = 0; i < index; i++)
{it.next();}
return it.next();
}
public Object removeElement(int index)
{
if(index<0)
{NoSuchElementException ex = new NoSuchElementException();
throw ex;}
if(index>size()-1)
{NoSuchElementException ex = new NoSuchElementException();
throw ex;}
Object result = null;
LinkedListIterator it = new LinkedListIterator();
result = getElement(index);
if(index<size()-1)
{
for(int i = 0; i<index+1; i++)
it.next();
while(index<size()-2)
{
it.set(getElement(index+1));
it.next();
index++;
}
it.remove();
}
else
{
for(int i = 0; i<index+1; i++)
it.next();
it.remove();
}
return result;
}
public String findSmallest() {
LinkedListIterator iterator = new LinkedListIterator();
if (!iterator.hasNext()){
return null;
}
String smallest = (String) getFirst();
while (iterator.hasNext()) {
if (smallest.compareToIgnoreCase((String) iterator.next()) > 1) {
smallest = (String) iterator.next();
}
}
return smallest;
}
public void searchAndReplace(Object first, Object second){
LinkedListIterator iterator = new LinkedListIterator();
while(iterator.hasNext()){
if(iterator.next().equals(first)){
iterator.set(second);
}
}
}
public void searchAndRemove(Object toBeRemoved){
LinkedListIterator iterator = new LinkedListIterator();
int a = 0;
while(iterator.hasNext()){
if(iterator.next().equals(toBeRemoved)){
removeElement(a);
}
a++;
}
}
public void reverseFirstSome(int howMany){
LinkedListIterator it = new LinkedListIterator();
if(size() > 1){
int top = howMany - 1;
int bot = 0;
it.next();
do{
LinkedListIterator it1 = new LinkedListIterator();
Object one = getElement(bot);
Object two = getElement(top);
it.set(two);
it.next();
for(int i = 0; i < top + 1; i++){
it1.next();
it1.set(one);
bot++;
top--;
}
}while(top > (size()/2) - 1);
}
}
//nested class to define its iterator
private class LinkedListIterator implements ListIterator
{
private Node position; //current position
private Node previous; //it is used for remove() method
// Constructs an iterator that points to the front
// of the linked list.
public LinkedListIterator()
{
position = null;
previous = null;
}
// Tests if there is an element after the iterator position.
public boolean hasNext()
{
if (position == null) //not traversed yet
{
if (first != null)
return true;
else
return false;
}
else
{
if (position.next != null)
return true;
else
return false;
}
}
// Moves the iterator past the next element, and returns
// the traversed element's data.
public Object next()
{
if (!hasNext())
{
NoSuchElementException ex = new NoSuchElementException();
throw ex;
}
else
{
previous = position; // Remember for remove
if (position == null)
position = first;
else
position = position.next;
return position.data;
}
}
// Adds an element after the iterator position
// and moves the iterator past the inserted element.
public void add(Object element)
{
if (position == null) //never traversed yet
{
addFirst(element);
position = first;
}
else
{
//making a new node to add
Node newNode = new Node();
newNode.data = element;
newNode.next = position.next;
//change the link to insert the new node
position.next = newNode;
//move the position forward to the new node
position = newNode;
}
//this means that we cannot call remove() right after add()
previous = position;
}
// Removes the last traversed element. This method may
// only be called after a call to the next() method.
public void remove()
{
if (previous == position) //not after next() is called
{
IllegalStateException ex = new IllegalStateException();
throw ex;
}
else
{
if (position == first)
{
removeFirst();
}
else
{
previous.next = position.next; //removing
}
//stepping back
//this also means that remove() cannot be called twice in a row.
position = previous;
}
}
// Sets the last traversed element to a different value.
public void set(Object element)
{
if (position == null)
{
NoSuchElementException ex = new NoSuchElementException();
throw ex;
}
else
position.data = element;
}
} //end of LinkedListIterator class
} // LinkedList類
對不起,這不是StackOverflow的工作方式。形式問題_「這裏有一堆代碼,請幫我解決它」_被認爲是脫離主題。請訪問[幫助]並閱讀[問]獲取更多信息,尤其是閱讀[爲什麼是「有人可以幫助我?」不是一個實際問題?](http://meta.stackoverflow.com/q/284236/18157 ) –
您可以通過調試器一行一行地完成代碼,並查看每行和每個方法是否完全符合您期望的列表。我猜你的頭腦中有正確的邏輯,但代碼並沒有達到你期望的程度。 –
@RayC我不確定,花了45分鐘才提出解決方案。 –