Python解答力扣网站题库简单版----第三讲

 

1041. 困于环中的机器人

题库链接: 1041. 困于环中的机器人.

题干

在无限的平面上,机器人最初位于 (0, 0) 处,面朝北方。机器人可以接受下列三条指令之一:

"G":直走 1 个单位

"L":左转 90 度

"R":右转 90 度

机器人按顺序执行指令 instructions,并一直重复它们。

只有在平面中存在环使得机器人永远无法离开时,返回 true。否则,返回 false。

示例 示例 1

输入:"GGLLGG" 输出:true 解释:机器人从 (0,0) 移动到 (0,2),转 180 度,然后回到 (0,0)。 重复这些指令,机器人将保持在以原点为中心,2 为半径的环中进行移动。

示例 2

输入:"GG" 输出:false 解释:机器人无限向北移动。

示例3

输入:"GL" 输出:true 解释: 机器人按 (0, 0) -> (0, 1) -> (-1, 1) -> (-1, 0) -> (0, 0) -> ... 进行移动。

提示

1 <= instructions.length <= 100

instructions[i] 在 {'G', 'L', 'R'} 中

思路

只要循环一次之后方向不是在向北或一次之后就在原点,

那么循环四次或者四次之内之后就可以回到初始位置

使用两个变量记录点的位置,使用两个变量记录机器人的方向。

遍历指令,如果为‘L’, 执行dx, dy = -dy, dx(横坐标为纵坐标的相反数,纵坐标为横坐标),如果为‘R’,执行dx, dy = dy, -dx(横坐标为纵坐标,纵坐标为横坐标的相反数)。

最后只要方向不向北或已经在原点机器人就可以离开。

代码解析

class Solution:

def isRobotBounded(self, instructions: str) -> bool:

x, y = 0, 0

dx, dy = 0, 1

for ins in instructions:

if ins == 'L':

dx, dy = -dy, dx

elif ins == 'R':

dx, dy = dy, -dx

else:

x, y = x + dx, y + dy

return (dx, dy) != (0, 1) or (x, y) == (0, 0)

运行结果

在这里插入图片描述

237. 删除链表中的节点

题库链接: 237. 删除链表中的节点.

题干

请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。

现有一个链表 -- head = [4,5,1,9],它可以表示为:

示例 示例 1

输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.

示例 2

输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9 .

说明

链表至少包含两个节点。

链表中所有节点的值都是唯一的。

给定的节点为非末尾节点并且一定是链表中的一个有效节点。

不要从你的函数中返回任何结果。

思路:

使本节点为删除节点的下一个点,删除节点的下一个点为删除节点的下下一个节点。

代码解析

# Definition for singly-linked list.

# class ListNode(object):

# def __init__(self, x):

# self.val = x

# self.next = None

class Solution(object):

def deleteNode(self, node):

"""

:type node: ListNode

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zgwxyf.html