1713. 得到子序列的最少操作次数
生活随笔
收集整理的這篇文章主要介紹了
1713. 得到子序列的最少操作次数
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
給你一個(gè)數(shù)組 target ,包含若干 互不相同 的整數(shù),以及另一個(gè)整數(shù)數(shù)組 arr ,arr 可能 包含重復(fù)元素。
每一次操作中,你可以在 arr 的任意位置插入任一整數(shù)。比方說,如果 arr = [1,4,1,2] ,那么你可以在中間添加 3 得到 [1,4,3,1,2] 。你可以在數(shù)組最開始或最后面添加整數(shù)。
請你返回 最少 操作次數(shù),使得 target 成為 arr 的一個(gè)子序列。
一個(gè)數(shù)組的 子序列 指的是刪除原數(shù)組的某些元素(可能一個(gè)元素都不刪除),同時(shí)不改變其余元素的相對順序得到的數(shù)組。比方說,[2,7,4] 是 [4,2,3,7,2,1,4] 的子序列(加粗元素),但 [2,4,2] 不是子序列。
示例 1:
輸入:target = [5,1,3], arr = [9,4,2,3,4]
輸出:2
解釋:你可以添加 5 和 1 ,使得 arr 變?yōu)?[5,9,4,1,2,3,4] ,target 為 arr 的子序列。
示例 2:
輸入:target = [6,4,8,1,3,2], arr = [4,7,6,2,3,8,6,1]
輸出:3
解題思路
代碼
func minOperations(target []int, arr []int) int {n := len(target)m:= make(map[int]int, n)for i, v := range target {m[v]=i}res := []int{}for _, v := range arr {if i2,has := m[v];has {searchInts := sort.SearchInts(res, i2)if searchInts<len(res) {res[searchInts]=i2}else {res=append(res,i2)}}}return n-len(res)} ```**加粗樣式**總結(jié)
以上是生活随笔為你收集整理的1713. 得到子序列的最少操作次数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 老是梦到不好的事情怎么回事
- 下一篇: 671. 二叉树中第二小的节点