日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

1713. 得到子序列的最少操作次数

發(fā)布時(shí)間:2023/11/29 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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

解題思路

  • 因?yàn)閿?shù)組 target包含若干互不相同的整數(shù),所以我們可以使用map完成數(shù)組元素和下標(biāo)的映射關(guān)系
  • 在遍歷arr數(shù)組的時(shí)候,可以根據(jù)map找出元素在target對應(yīng)的下標(biāo),因?yàn)轭}目要求添加最少元素使得 target 成為 arr 的一個(gè)子序列,因此我們的目標(biāo)就是在target數(shù)組中選出一個(gè)最長的子序列(該子序列同時(shí)也是arr的子序列),所以最終可以轉(zhuǎn)化為最長遞增子序列的問題,將arr數(shù)組映射成為target的下標(biāo)數(shù)組
  • 代碼

    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)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。