【LeetCode】剑指 Offer <二刷>(2)

简介: 【LeetCode】剑指 Offer <二刷>(2)

题目:剑指 Offer 04. 二维数组中的查找 - 力扣(LeetCode)

题目的接口:

func findNumberIn2DArray(matrix [][]int, target int) bool {
}

解题思路:

这道题一上来呢,作为暴力选手还是能一下想到暴力解法的,就是直接暴力枚举全部值查找即可,不过这道题非常的经典,所以我也直接能够想到他的优化解法,

至于我是怎么想到的,做的题多自然就能想到了,比较简单,根据题目的特性,可以从右上角或者左下角开始查找,我这里选择的右上角,然后如果当前位置比 target 小就往左查找如果当前位置比 target 大就往下查找,这样就优化成了 O(N) 的算法

代码:

func findNumberIn2DArray(matrix [][]int, target int) bool {
    i, j := len(matrix) - 1, 0
    for i >= 0 && j < len(matrix[0]) {
        if target < matrix[i][j] {
            i--
        } else if target > matrix[i][j] {
            j++
        } else {
            return true
        }
    }
    return false
}

过啦!!!

题目:剑指 Offer 05. 替换空格 - 力扣(LeetCode)

题目的接口:

func replaceSpace(s string) string {
}

解题思路:

这道题看完我能想到两个解法,一个是直接把空格替换成 %20 这样做的话时间复杂度很大,效率很低,很明显不适合,所以我就能想到第二种优化时间的方法,

方法二是再创建一个字符串,将就字符串追加到新字符串上,如果遇到空格就追加 %20,这个也是最容易想到的优化办法,但是空间复杂度会有所消耗,这里是代码:

func replaceSpace(s string) string {
    var arr string
    for _, c := range s {
        if c == ' ' {
            arr += "%20"
        } else {
            arr += string(c)
        }
    }
    return arr 
}

那有没有更好的算法呢?实际上是有的,这里我参考的是代码随想录发到 LeetCode 题解区的解法,用的是一个双指针的解法,具体操作如下:1)遍历原数组,根据需要的空间定量扩大原数组;2)从后往前遍历,一个指针指向原数组尾,另一个指向新的尾,遇到空格就追加 %20

代码:

func replaceSpace(s string) string {
    // 遍历原数组,并定量扩容
    b := []byte(s)
    length := len(b)
    spaceCount := 0
    for _, v := range b {
        if v == ' ' {
            spaceCount++
        }
    }
    reSize := spaceCount * 2
    tmp := make([]byte, reSize)
    b = append(b, tmp...)
    // 根据要求追加内容
    i := length - 1
    j := len(b) - 1
    for i >= 0 {
        if b[i] != ' ' {
            b[j] = b[i]
            i--
            j--
        } else {
            b[j] = '0'
            b[j - 1] = '2'
            b[j - 2] = '%'
            i--
            j -= 3
        }
    }
    return string(b)
}

过啦!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~

相关文章
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
64 6
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 26. 树的子结构
这篇文章提供了解决LeetCode上"剑指Offer 26. 树的子结构"问题的Python代码实现和解析,判断一棵树B是否是另一棵树A的子结构。
58 4
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 49. 丑数
解决剑指 Offer 49题"丑数"的Python实现,通过动态规划的方法计算出第n个丑数。
46 2
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 04. 二维数组中的查找
剑指Offer题目 "二维数组中的查找" 的Python解决方案,包括非递归迭代、递归以及使用内置函数的二分查找方法,以判断一个有序的二维数组中是否含有给定整数。
39 1
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 03. 数组中重复的数字
解决剑指Offer题目 "数组中重复的数字" 的Python实现方法,通过使用字典来记录数组中每个数字的出现次数,快速找出重复的数字。
44 1
|
5月前
|
iOS开发 MacOS
【Mac系统】解决Vscode中LeetCode插件不能刷剑指offer题库
文章讨论了解决Mac系统中Vscode里LeetCode插件无法刷剑指Offer题库的问题,并提供了一些相关的使用技巧和资源链接。
259 1
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 22. 链表中倒数第k个节点
Leetcode题目"剑指 Offer 22. 链表中倒数第k个节点"的Python解决方案,使用双指针法找到并返回链表中倒数第k个节点。
59 5
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 30. 包含min函数的栈
本文提供了实现一个包含min函数的栈的Python代码,确保min、push和pop操作的时间复杂度为O(1)。
35 4
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
Leetcode题目"剑指 Offer 21. 调整数组顺序使奇数位于偶数前面"的两种Python解决方案,一种是使用双端队列调整数组顺序,另一种是使用双指针法将奇数移到数组前半部分,偶数移到后半部分。
30 4
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 18. 删除链表的节点
Leetcode题目"剑指 Offer 18. 删除链表的节点"的Python解决方案,通过使用双指针法找到并删除链表中值为特定数值的节点,然后返回更新后的链表头节点。
46 4