【LeetCode】1409. 查詢帶鍵的排列 Queries on a Permutation With Key


題目地址:https://leetcode-cn.com/problems/string-matching-in-an-array/

題目描述

給你一個待查數組 queries ,數組中的元素爲 1 到 m 之間的正整數。 請你根據以下規則處理所有待查項 queries[i](從 i=0 到 i=queries.length-1):

一開始,排列 P=[1,2,3,...,m]
對於當前的 i ,請你找出待查項 queries[i] 在排列 P 中的位置(下標從 0 開始),然後將其從原位置移動到排列 P 的起始位置(即下標爲 0 處)。注意, queries[i] 在 P 中的位置就是 queries[i] 的查詢結果。
請你以數組形式返回待查數組 queries 的查詢結果。

示例 1:

輸入:queries = [3,1,2,1], m = 5
輸出:[2,1,2,1] 
解釋:待查數組 queries 處理如下:
對於 i=0: queries[i]=3, P=[1,2,3,4,5], 3 在 P 中的位置是 2,接着我們把 3 移動到 P 的起始位置,得到 P=[3,1,2,4,5] 。
對於 i=1: queries[i]=1, P=[3,1,2,4,5], 1 在 P 中的位置是 1,接着我們把 1 移動到 P 的起始位置,得到 P=[1,3,2,4,5] 。 
對於 i=2: queries[i]=2, P=[1,3,2,4,5], 2 在 P 中的位置是 2,接着我們把 2 移動到 P 的起始位置,得到 P=[2,1,3,4,5] 。
對於 i=3: queries[i]=1, P=[2,1,3,4,5], 1 在 P 中的位置是 1,接着我們把 1 移動到 P 的起始位置,得到 P=[1,2,3,4,5] 。 
因此,返回的結果數組爲 [2,1,2,1] 。  

示例 2:

輸入:queries = [4,1,2,2], m = 4
輸出:[3,1,2,0]

示例 3:

輸入:queries = [7,5,5,8,3], m = 8
輸出:[6,5,0,7,5]

提示:

  1. 1 <= m <= 10^3
  2. 1 <= queries.length <= m
  3. 1 <= queries[i] <= m

題目大意

給出了一段查詢串,並且查到誰就把誰放在前面,問每次命中的位置是什麼。

解題方法

模擬

數據的規模並不大,可以直接進行模擬。

Python代碼如下:

class Solution:
    def processQueries(self, queries: List[int], m: int) -> List[int]:
        P = list(range(1, m + 1))
        res = []
        for q in queries:
            idx = P.index(q)
            P = [q] + P[:idx] + P[idx+1:]
            res.append(idx)
        return res

歡迎關注負雪明燭的刷題博客,leetcode刷題800多,每道都講解了詳細寫法!

日期

2020 年 4 月 12 日 —— dp問題還是不太會

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章