LeetCode之旅(21)-Swap Nodes in Pairs
题目:
Given a linked list, swap every two adjacent nodes and return its head.
For example,
Given 1->2->3->4, you should return the list as 2->1->4->3.
Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.思路:
- 首先是判断head和head.next为空的情况,直接返回head
- 然后设置first和second两个变量,用来记录一前一后两个元素
- 设置pre来记录上一次最后的元素。pre.next = second;
-
代码:
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode swapPairs(ListNode head) {
        if(head == null||head.next == null){
            return head;
        }
        ListNode first = head;
        ListNode second = head.next;
        ListNode pre = null;
        ListNode swap = null;
        if(second != null){
            head = second;
        }
        while(first != null&&second != null){
            swap = second.next;
            second.next = first;
            first.next = swap;
            if(pre != null){
                pre.next = second;
            }
            pre = first;
            first = swap;
            if(swap != null){
                second = swap.next;
            }
        }
        return head;
    }
}LeetCode之旅(21)-Swap Nodes in Pairs的更多相关文章
- leetcode 【 Linked List Swap Nodes in Pairs 】 python 实现
		题目: Swap Nodes in Pairs Given a linked list, swap every two adjacent nodes and return its head. For ... 
- Leetcode 题目整理-6 Swap Nodes in Pairs  & Remove Duplicates from Sorted Array
		24. Swap Nodes in Pairs Given a linked list, swap every two adjacent nodes and return its head. For ... 
- leetcode第23题--Swap Nodes in Pairs
		Problem: Given a linked list, swap every two adjacent nodes and return its head. For example,Given 1 ... 
- LeetCode(24) Swap Nodes in Pairs
		题目 Given a linked list, swap every two adjacent nodes and return its head. For example, Given 1-> ... 
- 【leetcode❤python】24. Swap Nodes in Pairs
		#-*- coding: UTF-8 -*- # Definition for singly-linked list.# class ListNode(object):# def __init ... 
- leetcode个人题解——#24 Swap Nodes in Pairs
		因为不太熟悉链表操作,所以解决方法烦了点,空间时间多有冗余. 代码中l,r分别是每一组的需要交换的左右指针,temp是下一组的头指针,用于交换后链接:res是交换后的l指针,用于本组交换后尾指针在下一 ... 
- [Leetcode][Python]24: Swap Nodes in Pairs
		# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 24: Swap Nodes in Pairshttps://oj.leetc ... 
- 【LeetCode】Swap Nodes in Pairs  链表指针的应用
		题目:swap nodes in pairs <span style="font-size:18px;">/** * LeetCode Swap Nodes in Pa ... 
- 【LeetCode】Swap Nodes in Pairs 解题报告
		Swap Nodes in Pairs [LeetCode] https://leetcode.com/problems/swap-nodes-in-pairs/ Total Accepted: 95 ... 
- 【LeetCode练习题】Swap Nodes in Pairs
		Swap Nodes in Pairs Given a linked list, swap every two adjacent nodes and return its head. For exam ... 
随机推荐
- 侧滑面板(对viewGroup的自定义)
			额,好吧,最近一直在做侧滑的事情,到目前为止一共是学了三种方法了,一个是直接加第三方开源框架SlidingMenu,第二给是用DrawerLayout,今天这个是用谷歌官方提供的在新的support- ... 
- iOS开发之使用block块进行数据遍历的方法
			看了一篇文章,发现遍历数组.字典中的数据时,除了使用for循环外,还可以使用block块进行操作,瞬间感觉iOS的语言代码确实有点高大上的感觉,下面就简单的介绍一下这个方法. 首先是最基本的运用形式, ... 
- JQuery之动画与特效
			显示与隐藏 show(spped,[callback])与hide(spped,[callback]) speed可选填slow.normal.fast,对应的速度分别为600ms.400ms.200 ... 
- 详解EBS接口开发之采购申请导入
			更多内容可以参考我的博客  详解EBS接口开发之采购订单导入 http://blog.csdn.net/cai_xingyun/article/details/17114697 /*+++++++ ... 
- Xcode中为何要为设置bundle和App分别设置两份一样的图片资源
			大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道在App设置的bundle中有时也会用到图片资源,而在 ... 
- Android对话框AlertDialog-android学习之旅(四十二)
			对话框简介 android提供了丰富的对话框支持,支持四种如下的对话框. AlertDialog简介 介绍上面六个方法的代码示例 setMessage() <?xml version=" ... 
- IMX51---GPIO
			GPIO(General Purpose Input/Output)指通用输入/输出,IMX51的GPIO模块提供32位双向的.通用输入和输出的信号,下图是GPIO的框图: 图1 1. GP ... 
- java同步synchronized
			java同步synchronized volatile仅仅用来保证该变量对所有线程的可见性,但不保证原子性. 看下面的这段代码: /** * * @author InJavaWeTrust * */ ... 
- 在CSDN开通博客专栏后如何发布文章(图文)
			今天打开电脑登上CSDN发现自己授予了专栏勋章,有必要了解如何在专栏发布文章. 很感谢已经有前辈给出了图文教程,此文章转载自博客:http://blog.csdn.net/upi2u/article/ ... 
- cocos2D v3.4 在TileMap中开启高清显示
			在Tiled中制作一幅地图,用的图片砖块分辨率为32x32. iOS设备为iPhone 4s. 在未打开高清屏支持的cocos2d v2.x版本中,运行log显示480x320.遂启用高清屏支持: [ ... 
