- 作者: 負雪明燭
- id: fuxuemingzhu
- 個人博客:http://fuxuemingzhu.cn/
題目地址: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 <= m <= 10^3
1 <= queries.length <= m
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問題還是不太會