LeetCode—<双指针专项>剑指 Offer 18、21、22、25、52、57、58 - I

剑指 Offer 18. 删除链表的节点、21. 调整数组顺序使奇数位于偶数前面、22. 链表中倒数第k个节点、25. 合并两个排序的链表、52. 两个链表的第一个公共节点、57. 和为s的两个数字、58 - I. 翻转单词顺序

题目描述:
[18]
给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。
返回删除后的链表的头节点。
在这里插入图片描述
[21]
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。
在这里插入图片描述
[22]
输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。
例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。
在这里插入图片描述
[25]
输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。
在这里插入图片描述
[52]

在这里插入图片描述
[57]
输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,则输出任意一对即可。
在这里插入图片描述
[58 - I]
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. “,则输出"student. a am I”。在这里插入图片描述

考察重点
第18题一个指针匹配目标删除节点,一个节点记录该节点的上一位,便于删除
第21题使用left,right分别指向数组左右,分别搜索偶数与奇数,二者分别指向目标节点后,交换二者位置,直到 left>=right
第22题slow指针从首节点开始,quick指针向后移k位,当quick指向末尾,slow即指向倒数第k位
第25题合并链表,每次比较两链表头结点并将小的节点加入结果链表,直到遍历完成两链表
第52题假设两链表长度分别为A和B,则有A+B=B+A,即分别用两指针从两链表头结点开始向后移动,分别到达末尾处后,则从另一链表头结点重新开始向后移动,则二者必会在交点处相交
第57题使用slow记录其中一个结果数字,二分法在slow之后查找第二个结果数字
第58 - I题slow记录每个单词起始位置,quick记录每个单词终止位置,遍历整个字符串

第18题

func deleteNode(head *ListNode, val int) *ListNode {temp := &ListNode{}temp.Next = headlay := temp     // lay延迟一位,负责在head找到目标节点时,执行删除操作for head != nil{if head.Val == val{lay.Next = lay.Next.Nextreturn temp.Next}lay = headhead = head.Next}return temp.Next
}

第21题

func isOdd(num int)bool{return num % 2 == 1
}
func change(nums []int, a, b int){temp := nums[a]nums[a] = nums[b]nums[b] = temp
}
func exchange(nums []int) []int {left, right := 0, len(nums) - 1for left < right{for left < right && isOdd(nums[left]){left ++}for left < right && !isOdd(nums[right]){right --}if left < right{change(nums, left, right) }}return nums
}

第22题

func getKthFromEnd(head *ListNode, k int) *ListNode {quick, slow := head, headfor i := 0;i < k;i ++{quick = quick.Next}for quick != nil{slow = slow.Next;quick = quick.Next;}return slow;
}

第25题

func mergeTwoLists(l1 *ListNode, l2 *ListNode) *ListNode {res := &ListNode{}temp := resfor l1 != nil || l2 != nil{if l1 == nil{   // 任意一方为空,则将另一方的全部元素加入结果链表尾部res.Next = l2break}if l2 == nil{res.Next = l1break}if l1.Val < l2.Val{res.Next = l1res = res.Nextl1 = l1.Next}else{res.Next = l2res = res.Nextl2 = l2.Next}}return temp.Next
}

第52题

func getIntersectionNode(headA, headB *ListNode) *ListNode {if headA == nil || headB == nil{return nil}tempA, tempB := headA, headBfor headA != headB{headA = headA.NextheadB = headB.Nextif headA == nil && headB == nil{break}if headA == nil{headA = tempB}if headB == nil{headB = tempA}}return headA
}

第57题

func twoSum(nums []int, target int) []int {slow, nLen := 0, len(nums)for slow < nLen{left, right := slow + 1, nLen - 1for left <= right{mid := left + (right - left) / 2if nums[mid] == target - nums[slow]{return []int{nums[slow], nums[mid]}}else if nums[mid] < target - nums[slow]{left = mid + 1}else{right = mid - 1}}slow ++}return []int{}
}

第58 - I题

func reverseWords(s string) string {res := ""for slow := 0;slow < len(s);{if s[slow] == ' '{slow ++continue}quick := slow + 1for ;quick < len(s);quick ++{if s[quick] == ' '{break}} if len(res) == 0{res = s[slow:quick]}else{res = s[slow:quick] + " " + res}slow = quick + 1}return res 
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/263222.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android应用程序绑定服务(bindService)的过程源代码分析

Android应用程序组件Service与Activity一样&#xff0c;既可以在新的进程中启动&#xff0c;也可以在应用程序进程内部启动&#xff1b;前面我们已经分析了在新的进程中启动Service的过程&#xff0c;本文将要介绍在应用程序内部绑定Service的过程&#xff0c;这是一种在应用程…

递归-汉诺塔

#A&#xff1a;起始&#xff0c;B&#xff1a;中间&#xff0c;C&#xff1a;最后count0def hanoi(n,A,B,C): global count if n1: print("{}:{}->{}".format(1,A,C)) count1 else: hanoi(n-1,A,C,B) #将前n…

Bootstrap系列 -- 8. 代码显示

一. Bootstrap中的代码块 代码块一般在博客中使用的较多&#xff0c;比较博客园中提供的贴代码. 在Bootstrap中提供了三种形式的代码显示 1. 使用<code></code>来显示单行内联代码 2. 使用<pre></pre>来显示多行块代码 3. 使用<kbd></kbd>…

PowerDesigner12对SQL2005反向工程问题.

用PowerDesigner12利用ODBC连接SQL2005进行反向工程&#xff0c;总分报错[Microsoft][ODBC SQL Server Driver][SQL Server]未能准备评语句SQLSTATE37000解决办法&#xff1a;把&#xff02;更改默认的数据库为&#xff02;这个选项去掉在中选择要进行操做的数据库.转载于:http…

LeetCode—<搜索与回溯专项>剑指 Offer 12、13、34、36、54

剑指 Offer 12. 矩阵中的路径、13. 机器人的运动范围、34. 二叉树中和为某一值的路径、36. 二叉搜索树与双向链表、54. 二叉搜索树的第k大节点 题目描述&#xff1a; [12] 给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中&#xff0c;返回…

导数--基本概念

转载于:https://www.cnblogs.com/liuys635/p/11242741.html

解决IE6、IE7、Firefox兼容最简单的CSS Hack

写三句代码来控制一个属性&#xff0c;区别Firefox&#xff0c;IE7&#xff0c;IE6&#xff1a; background:orange; *background:green !important; *background:blue; 说明&#xff1a;这段代码会使在Firefox中&#xff0c;背景呈橙色&#xff1b;IE7中为绿色&#xf…

[导入]创建、查询、修改带名称空间的 XML 文件的例子

XML的应用越来越广泛了&#xff0c;如Vista、Flex编程都将使用 XML&#xff0c;正确掌握XML的各种操作&#xff0c;对提高编程效率至关重要。下面就是一个综合处理带名称空间的XML的例子。 文章来源:http://blog.csdn.net/net_lover/archive/2006/12/18/1447434.aspx 转载于:ht…

Kernel那些事儿之内存管理(2) --- 百闻不如一见

上次介绍了物理内存管理中三位主要人物中的node 和zone。这两位是当官的&#xff0c;一个是县长&#xff0c;一个是里长&#xff0c;不敢不先介绍啊。接下来出场的就是我们的老百姓了 --- page frame。Page frame是物理内存的基本组成单位&#xff0c;在Kernel中由结构体 struc…

LeetCode—<排序专项>剑指 Offer 40、41、45、61

剑指 Offer 40. 最小的k个数、41. 数据流中的中位数、45. 把数组排成最小的数、61. 扑克牌中的顺子 题目描述&#xff1a; [40] 输入整数数组 arr &#xff0c;找出其中最小的 k 个数。例如&#xff0c;输入4、5、1、6、2、7、3、8这8个数字&#xff0c;则最小的4个数字是1、2…

归并 快排 快速幂

/* 归并排序&#xff1a;不断将数组切分为两部分递归切分直到数组长度为1&#xff0c;之后逐渐有序合并 */ #include <cstdio> #include <iostream> #include <cmath> using namespace std;//归并 小-->大 void Merge(int a[], int s, int m, int e, int …

dev GridControl双击行事件

今天用到了gridcontrol这个控件,要求写一个gridview的双击事件,因为想要的效果是只双击行才出Message,用gridview的Double_Click我没实现,后来想到MouseDown,一试,很简单,首先,仍旧需要将gridview1.OptionsBehavior.Editable设为false,下面是代码: Skelta BPM.NET&#xff08…

自己动手编写一个ajax extender

该扩展的功能有以下几点&#xff1a;1、当鼠标移到某个按钮上时&#xff0c;该按钮显示一个Css样式&#xff1b;2、当鼠标移开该按钮时&#xff0c;该按钮显示另外一个Css样式&#xff1b;3、当鼠标点击该按钮时&#xff0c;执行一个用户自己定义的javascript函数&#xff1b; …

jQuery:表格的奇偶行变色,jquery实例之表格隔一行

jQuery:表格的奇偶行变色<html> <head> <title>表格变色</title> <style type"text/css"> .odd{background:#ffffee;} .even{background:#fff38f;} .first{background:red;} .last{background:blue;}…

分金币 Uva 11300

题意 给定N个人成环状坐&#xff0c;每个人初始分配Ai的金币&#xff0c;金币总数可以被N整除&#xff0c;每个人可以给左右相邻的人一定数量的金币使得最终每个人的金币数量相同&#xff0c;求转移数量最小的方案所转移的总金币数量。 N<1000000 对每组数据保证输出在INT64…

LeetCode—<搜索与回溯专项>剑指 Offer 55 - I、55 - II、64、68 - I、68 - II

剑指 Offer 55 - I. 二叉树的深度、55 - II. 平衡二叉树、64. 求12…n、68 - I. 二叉搜索树的最近公共祖先、68 - II. 二叉树的最近公共祖先 题目描述&#xff1a; [55 - I] [55 - II] [64] 求 12…n &#xff0c;要求不能使用乘除法、for、while、if、else、switch、case等关…

Tip:使用Extender的ResolveControlID事件

1、分析 不知道大家在使用ASP.NET AJAX Control Toolkit里的各个Extender控件时&#xff0c;有没有接触过ResolveControlID事件&#xff1f;这个事件在官方也只用了很少的笔墨来描述。的确&#xff0c;这个事件不太常用&#xff0c;看看ASP.NET AJAX的演示站点&#xff0c;根本…

我常用的shell命令

我常用的shell命令tar:tar jxvf filename.tar.bz2tar xvf filename.tartar cvf filename.tar file tar cjvf filename.tar.bz2 file wc:ls -l | wc -ltr:ls -l | tr a-z A-Zgrep:ls -l | grep ^dls -l | grep -n ^dls -l | grep -v ^decho "theaaaathebbbbthe | grep \<…

Git常用命令整理

git init # 初始化本地git仓库&#xff08;创建新仓库&#xff09;git config --global user.name "xxx" # 配置用户名git config --global user.email "xxxxxx.com" # 配置邮件git config --global color.ui true # git status等命令自动着色git config -…

LeetCode—<分治专项>剑指 Offer 07、16、33

剑指 Offer 07. 重建二叉树、16. 数值的整数次方、33. 二叉搜索树的后序遍历序列 题目描述&#xff1a; [07] 输入某二叉树的前序遍历和中序遍历的结果&#xff0c;请构建该二叉树并返回其根节点。 假设输入的前序遍历和中序遍历的结果中都不含重复的数字。 [16] 实现 pow(x,…