【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)
}

过啦!!!

写在最后:

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

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

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

相关文章
|
2月前
|
存储
【LeetCode】剑指 Offer 54. 二叉搜索树的第k大节点
【LeetCode】剑指 Offer 54. 二叉搜索树的第k大节点
26 1
|
2月前
|
算法 DataX
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
|
2月前
|
算法 定位技术
【leetcode】剑指 Offer II 105. 岛屿的最大面积-【深度优先DFS】
【leetcode】剑指 Offer II 105. 岛屿的最大面积-【深度优先DFS】
26 0
|
2月前
|
Go
golang力扣leetcode 剑指Offer II 114. 外星文字典
golang力扣leetcode 剑指Offer II 114. 外星文字典
31 0
|
2月前
「LeetCode」剑指 Offer 40. 最小的k个数
「LeetCode」剑指 Offer 40. 最小的k个数
36 0
|
2月前
leetcode 剑指 Offer 32 - III. 从上到下打印二叉树 III
leetcode 剑指 Offer 32 - III. 从上到下打印二叉树 III
28 0
|
2月前
leetcode 剑指 Offer 32 - II. 从上到下打印二叉树 II
leetcode 剑指 Offer 32 - II. 从上到下打印二叉树 II
31 0
|
2月前
/leetcode 剑指 Offer 32 - I. 从上到下打印二叉树
/leetcode 剑指 Offer 32 - I. 从上到下打印二叉树
26 0
|
18天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
18天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题