大家好,我正在尝试在两个双链接列表之间完全交换两个节点(值和地址也是)。只有位于相同位置的节点才能在两个节点之间交换,即位置2的节点只能由另一个LinkedList中位置2的节点交换。考虑下面的2个链接列表示例:
815 102 162 524
622 101 830 754
假设我们想交换第三个元素,即162和830。交换后,领英列表变成:
815 102 830 524
622 101 162 754
我已经尝试了下面的代码,但它不能替换前面的元素。
void swapNodes(Node* firstListNode, Node* secondListNode)
{
Node* FirstNodeNext = firstListNode->next;
Node* FirstNodePrev = firstListNode->previous;
Node* SecondNodeNext = secondListNode->next;
Node* SecondNodePrev = secondListNode->previous;
//if the nodes are heads
if (firstListNode->previous == NULL && secondListNode->previous == NULL)
{
firstListNode->next = SecondNodeNext;
secondListNode->next = FirstNodeNext;
}
// if the nodes are tails
else if(firstListNode->next == NULL && secondListNode->next == NULL)
{
firstListNode->previous = SecondNodePrev;
secondListNode->previous = FirstNodePrev;
}
else
{
firstListNode->next = SecondNodeNext;
firstListNode->previous = SecondNodePrev;
secondListNode->next = FirstNodeNext;
secondListNode->previous = FirstNodePrev;
}
}
我怎样才能完成这项任务?
elseif不交换前面的元素,例如,如果我们将值524和754传递给函数,它应该是尾部,并执行elseif语句,因为它没有下一个节点。
交换后应该是:
815 102 162 754
622 101 830 524
代码不交换以前的节点。
我认为您正在丢失在其他linkedlist中交换的引用,下面是java中相同的工作代码段。请注意,我在这里假设两个linkedlist的长度相同。
public class Application {
static class Node{
private int value;
private Node prev;
private Node next;
public Node(int value){
this.value = value;
}
public void print(){
for(Node node=this; node!=null; node = node.next){
System.out.print(node.value + "->");
}
System.out.println();
}
}
public static void main(String[] args) {
Node head1 = new Node(815);
addNodeAtLast(head1, 102);
addNodeAtLast(head1, 162);
addNodeAtLast(head1, 524);
head1.print();
Node head2 = new Node(622);
addNodeAtLast(head2, 101);
addNodeAtLast(head2, 830);
addNodeAtLast(head2, 754);
head2.print();
swapAtIndex(head1, head2, 3);
head1.print();
head2.print();
}
private static void swapAtIndex(Node head1, Node head2, int index){
System.out.println("Swaping node at index : "+index);
if(index == 0){
Node tmp = head1.next;
head1.next= head2.next;
head2.next = tmp;
return;
}
Node linkedList1Ref = head1, linkedList2Ref = head2;
for(int i=0; i!=index; ++i, linkedList1Ref = linkedList1Ref.next, linkedList2Ref=linkedList2Ref.next);
Node temp2Prev = linkedList2Ref.prev;
Node temp2Nxt = linkedList2Ref.next;
linkedList1Ref.prev.next = linkedList2Ref; // LinkedList 1 swap
linkedList2Ref.prev = linkedList1Ref.prev; // LinkedList 1 swap
if(linkedList2Ref.next != null && linkedList1Ref.next != null) {
linkedList2Ref.next = linkedList1Ref.next; // LinkedList 1 swap
linkedList1Ref.next.prev = linkedList2Ref; // LinkedList 1 swap
}
temp2Prev.next = linkedList1Ref;
linkedList1Ref.prev = temp2Prev;
if(linkedList1Ref.next != null && temp2Nxt != null) {
linkedList1Ref.next = temp2Nxt;
temp2Nxt.prev = linkedList1Ref;
}
}
private static void addNodeAtLast(Node head, int value){
Node temp = new Node(value);
Node prev = null;
for(prev=head; prev.next != null; prev=prev.next);
temp.prev = prev;
prev.next = temp;
}
}
我遇到了一个问题,在这个问题中,您应该交换双链接列表中的一组节点。例如:对于列表
我在Java中实现一个双链接列表时遇到了一个问题。特别是要交换2个以下节点(在我的例子中,一个节点包含一个政治候选人)。 假设下面的DLL: head- 作为输出,我没有从头到尾的正确DLL,但从头到尾都很好: 我已经写了几个版本的这个方法reverseTwoNode。我甚至尝试在节点内部交换数据,而不是交换节点,我也有同样的问题。你能帮我真是太好了,我花了这么多时间在这个简单的功能上,我看不出有
我的代码中有错误。错误是:错误:类SwapNodes是公共的,应该在名为SwapNodes的文件中声明。java公共类SwapNodes{ ^Main.java:104:错误:内部类SwapNodes中的静态声明非法。Main公共静态void Main(String[]args){ ^modifier'static'仅允许在常量变量声明中使用。我的程序如下所示:
我在谷歌上搜索了这个,但他们都在谈论“交换节点而不交换数据”。 我尝试自己编写一个交换节点方法: 如您所见,和相互更改,但打印结果不交换。如何交换两个节点及其数据? 编辑:下面的完整示例
我正在尝试编写一个函数,它接受一个项目并将其插入双向链表的前端。双向链表有两个虚拟节点,两端各一个。我迄今为止编写的方法在迭代列表并打印时只返回两个虚拟节点。我无法弄清楚我的代码有什么问题。 当我运行main时,我得到的只是: 然而,我预计: 有谁能告诉我如何修复代码,以便在双链接列表的开头添加一个项目,在两个虚拟的第一个和最后一个节点之间?
给定单链接列表: