Golang每日一练(leetDay0086) 回文链表、删除链表节点

news/2024/5/18 22:10:22

目录

234. 回文链表 Palindrome Linked-list  🌟

237. 删除链表中的节点 Delete Node In a Linked-list  🌟🌟

🌟 每日一练刷题专栏 🌟

Rust每日一练 专栏

Golang每日一练 专栏

Python每日一练 专栏

C/C++每日一练 专栏

Java每日一练 专栏


234. 回文链表 Palindrome Linked-list

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

示例 1:

输入:head = [1,2,2,1]
输出:true

示例 2:

输入:head = [1,2]
输出:false

提示:

  • 链表中节点数目在范围[1, 10^5] 内
  • 0 <= Node.val <= 9

进阶:你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?

代码1:

package main

import "fmt"

type ListNode struct {
	Val  int
	Next *ListNode
}

func isPalindrome(head *ListNode) bool {
	if head == nil {
		return true
	}
	slow, fast := head, head
	var stack []int
	for fast != nil && fast.Next != nil {
		stack = append(stack, slow.Val)
		slow = slow.Next
		fast = fast.Next.Next
	}
	// odd length
	if fast != nil {
		slow = slow.Next
	}
	for slow != nil {
		if len(stack) == 0 || slow.Val != stack[len(stack)-1] {
			return false
		}
		stack = stack[:len(stack)-1]
		slow = slow.Next
	}
	return true
}

func createLinkedList(nums []int) *ListNode {
	if len(nums) == 0 {
		return nil
	}
	head := &ListNode{Val: nums[0]}
	cur := head
	for i := 1; i < len(nums); i++ {
		cur.Next = &ListNode{Val: nums[i]}
		cur = cur.Next
	}
	return head
}

func printLinkedList(head *ListNode) {
	cur := head
	for cur != nil {
		fmt.Print(cur.Val, "->")
		cur = cur.Next
	}
	fmt.Println("nil")
}

func main() {
	nums := []int{1, 2, 2, 1}
	head := createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))

	nums = []int{1, 2}
	head = createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))
}

代码2:

package main

import "fmt"

type ListNode struct {
	Val  int
	Next *ListNode
}

func isPalindrome(head *ListNode) bool {
    if head == nil {
        return true
    }
    slow, fast := head, head
    for fast != nil && fast.Next != nil {
        slow = slow.Next
        fast = fast.Next.Next
    }
    var prev *ListNode
    for slow != nil {
        next := slow.Next
        slow.Next = prev
        prev = slow
        slow = next
    }
    for prev != nil && head != nil {
        if prev.Val != head.Val {
            return false
        }
        prev = prev.Next
        head = head.Next
    }
    return true
}

func createLinkedList(nums []int) *ListNode {
	if len(nums) == 0 {
		return nil
	}
	head := &ListNode{Val: nums[0]}
	cur := head
	for i := 1; i < len(nums); i++ {
		cur.Next = &ListNode{Val: nums[i]}
		cur = cur.Next
	}
	return head
}

func printLinkedList(head *ListNode) {
	cur := head
	for cur != nil {
		fmt.Print(cur.Val, "->")
		cur = cur.Next
	}
	fmt.Println("nil")
}

func main() {
	nums := []int{1, 2, 2, 1}
	head := createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))

	nums = []int{1, 2}
	head = createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))
}

代码3:

package main

import "fmt"

type ListNode struct {
	Val  int
	Next *ListNode
}

var left *ListNode

func isPalindrome(head *ListNode) bool {
	left = head
	return traverse(head)
}

func traverse(right *ListNode) bool {
	if right == nil {
		return true
	}
	res := traverse(right.Next)
	res = res && (left.Val == right.Val)
	left = left.Next
	return res
}

func createLinkedList(nums []int) *ListNode {
	if len(nums) == 0 {
		return nil
	}
	head := &ListNode{Val: nums[0]}
	cur := head
	for i := 1; i < len(nums); i++ {
		cur.Next = &ListNode{Val: nums[i]}
		cur = cur.Next
	}
	return head
}

func printLinkedList(head *ListNode) {
	cur := head
	for cur != nil {
		fmt.Print(cur.Val, "->")
		cur = cur.Next
	}
	fmt.Println("nil")
}

func main() {
	nums := []int{1, 2, 2, 1}
	head := createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))

	nums = []int{1, 2}
	head = createLinkedList(nums)
	printLinkedList(head)
	fmt.Println(isPalindrome(head))
}

输出:

1->2->2->1->nil
true
1->2->nil
false


237. 删除链表中的节点 Delete Node In a Linked-list

请编写一个函数,用于 删除单链表中某个特定节点 。在设计函数时需要注意,你无法访问链表的头节点 head ,只能直接访问 要被删除的节点 。

题目数据保证需要删除的节点 不是末尾节点 。

示例 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

提示:

  • 链表中节点的数目范围是 [2, 1000]
  • -1000 <= Node.val <= 1000
  • 链表中每个节点的值都是 唯一 的
  • 需要删除的节点 node 是 链表中的节点 ,且 不是末尾节点

代码:

package main

import "fmt"

type ListNode struct {
	Val  int
	Next *ListNode
}

func deleteNode(node *ListNode) {
	node.Val = node.Next.Val
	node.Next = node.Next.Next
}

func printLinkedList(head *ListNode) {
	cur := head
	for cur != nil {
		fmt.Print(cur.Val, "->")
		cur = cur.Next
	}
	fmt.Println("nil")
}

func main() {
	node1 := &ListNode{4, nil}
	node2 := &ListNode{5, nil}
	node3 := &ListNode{1, nil}
	node4 := &ListNode{9, nil}
	node1.Next = node2
	node2.Next = node3
	node3.Next = node4
	deleteNode(node2)
	printLinkedList(node1)

	node1 = &ListNode{4, nil}
	node2 = &ListNode{5, nil}
	node3 = &ListNode{1, nil}
	node4 = &ListNode{9, nil}
	node1.Next = node2
	node2.Next = node3
	node3.Next = node4
	deleteNode(node3)
	printLinkedList(node1)
}

输出:

4->1->9->nil

4->5->9->nil


🌟 每日一练刷题专栏 🌟

持续,努力奋斗做强刷题搬运工!

👍 点赞,你的认可是我坚持的动力! 

🌟 收藏,你的青睐是我努力的方向! 

评论,你的意见是我进步的财富!  

 主页:https://hannyang.blog.csdn.net/ 

Rust每日一练 专栏

(2023.5.16~)更新中...

Golang每日一练 专栏

(2023.3.11~)更新中...

Python每日一练 专栏

(2023.2.18~2023.5.18)暂停更

C/C++每日一练 专栏

(2023.2.18~2023.5.18)暂停更

Java每日一练 专栏

(2023.3.11~2023.5.18)暂停更


http://www.niftyadmin.cn/n/393884.html

相关文章

Java数据驱动:CData JDBC Drivers 2022 Crack

JDBC 驱动程序 易于使用的 JDBC 驱动程序&#xff0c;具有强大的企业级功能 无与伦比的性能和可扩展性。 对实时数据的简单 JDBC/SQL 访问。 从流行的 BI 工具访问实时数据。 集成到流行的 IDE 中。 CData JDBC Drivers Software 是领先的数据访问和连接解决方​​案提供商。我…

UART串口通信实验

不管是单片机开发还是嵌入式 Linux 开发&#xff0c;串口都是最常用到的外设。 可以通过串口将开发板与电脑相连&#xff0c;然后在电脑上通过串口调试助手来调试程序。 还有很多模块&#xff0c;比如蓝牙、GPS、GPRS等都使用串口与主控进行通信。 UART简介 串口全称串行接口…

【ARMv8 SIMD和浮点指令编程】NEON 减法指令——减法也好几种

向量减法包括常见的普通加指令&#xff0c;还包括长减、宽减、半减、饱和减、按对减、按对加并累加、选择高半部分结果加、全部元素加等。 1 SUB 减法&#xff08;向量&#xff09;&#xff0c;该指令从第一个源 SIMD&FP 寄存器中的相应向量元素中减去第二个源 SIMD&…

什么是循环语句?如何使用for循环、while循环和do-while循环?

1. 引言&#xff1a; 循环语句是一种编程结构&#xff0c;用于重复执行一段代码块&#xff0c;直到满足特定条件为止。它在程序中起到了简化代码、提高效率和处理大量数据的重要作用。在本文中&#xff0c;我们将详细讨论三种常见的循环语句&#xff1a;for循环、while循环和do…

chatgpt赋能python:Python中取某个元素的技巧

Python 中取某个元素的技巧 作为一种强大而灵活的编程语言&#xff0c;Python 常常被用来处理各种数据集合&#xff0c;如列表、元组、字典等。在处理这些数据集合的过程中&#xff0c;取某个元素的需求很常见&#xff0c;同时也有多种实现方法。在本文中&#xff0c;我们…

前端046_单点登录SSO_初始化项目(Vue-CLI)

初始化项目 1、安装 node.js 和 npm2、安装 Vue-CLI 脚手架3、导入单点登录项目模版1、安装 node.js 和 npm 下载 http://nodejs.cn/download/安装 查看 npm 版本[root@pgdb ~]# node -v v12.22.12配置 npm 淘宝镜像命令npm config set registry https://registry

软件工程导论(三)系统概要设计

一、系统设计概述 1.1系统设计概述 设计和抽象 系统行为驱动完成设计面向对象设计系统数据驱动完成设计 面向操作的设计 面向数据的设计 设计主要分为三个步骤&#xff1a; 概要设计&#xff1a;接收需求的文档&#xff0c;完成模块的分解 详细设计&#xff1a;根据分解…

flink自动加全局流水

from pyflink.datastream import StreamExecutionEnvironment from pyflink.datastream.functions import MapFunction, RuntimeContext, KeyedProcessFunction import re import redis # 创建 StreamExecutionEnvironment 对象 env StreamExecutionEnvironment.get_executi…