内容简介:给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。示例:
题目描述
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
说明:
- 你的算法只能使用常数的额外空间。
- 你不能只是单纯的改变节点内部的值 ,而是需要实际的进行节点交换。
代码实现
// ListNode Definition for singly-linked list.
type ListNode struct {
Val int
Next *ListNode
}
func swapPairs(head *ListNode) *ListNode {
if head == nil || head.Next == nil {
return head
}
var prev *ListNode
cur := head
head = cur.Next
for ; cur != nil && cur.Next != nil; cur = cur.Next {
next := cur.Next
//注意:第一次循环时,prev为nil
if prev != nil {
prev.Next = next
}
//交换两个节点
cur.Next, next.Next, prev = next.Next, cur, cur
}
return head
}
GitHub
- 源码传送门
- 项目中会提供各种数据结构及算法的Golang实现, LeetCode解题思路及答案
题目来源
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- LeetCode (24):两两交换链表中的节点
- 画解算法:24. 两两交换链表中的节点
- 为您的 NIEM 交换建模
- RabbitMQ消息交换模式简介
- DSMM之数据交换安全
- 为何要用到三层交换机?监控系统中三层交换机选择的七项指标
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Head First Rails
David Griffiths / O'Reilly Media / 2008-12-30 / USD 49.99
Figure its about time that you hop on the Ruby on Rails bandwagon? You've heard that it'll increase your productivity exponentially, and allow you to created full fledged web applications with minimal......一起来看看 《Head First Rails》 这本书的介绍吧!