java单链表交换相邻元素_1.7交换链表中的相邻节点

该博客介绍了如何使用Java交换单链表中的相邻元素。解题思路采用就地逆序法,通过调整节点指针来交换相邻节点。代码实现包括创建链表、打印链表、交换节点和测试案例,展示了交换后链表的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

交换链表中的相邻节点

题目描述:

把链表相邻元素翻转,例如给定链表为1——>2一>3一>4一>5——>6一>7,则翻转后的链表变为2一>1一>4一>3一>6一>5一>7

解题思路:

就地逆序法:

通过调整结点指针域的指向来直接调换相邻的两个结点。如果单链表恰好有偶数个结点,那么只需要将奇偶结点对调即可,如果链表有奇数个结点,那么只需要将除最后一个结点外的其它结点进行奇偶对调即可。

54b9f6e7e4d7e7996636ff4156994096.png

代码实现:

# -*-coding:utf-8-*-

"""

@Author : 图南

@Software: PyCharm

@Time : 2019/9/6 18:34

"""

class Node:

def __init__(self, data=None, next=None):

self.data = data

self.next = next

def print_link(head):

if head is None or head.next is None:

return None

cur = head.next

while cur.next != None:

print(cur.data, end=' ')

cur = cur.next

print(cur.data)

def con_link(n):

head = Node()

cur = head

for i in range(1, n+1):

node = Node(i)

cur.next = node

cur = node

return head

def reverseNode(head):

pre = head

cur = pre.next

while cur is not None and cur.next is not None:

next = cur.next

pre.next = next

cur.next = next.next

next.next = cur

pre = cur

cur = pre.next

return head

if __name__ == '__main__':

head = con_link(6)

print_link(head)

head = reverseNode(head)

print_link(head)

运行结果:

3637f20e91e23756d5c025037facccac.png

cf20fd8831446bd2d5ef1d04e5262f30.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值