亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在給定的數組段中查找最小數

在給定的數組段中查找最小數

呼啦一陣風 2022-07-27 16:42:17
假設我們有一個很大的整數數組 A。我們想要回答許多查詢,例如:找到索引 0 和 100 之間的最小值找到索引 4 和 90 之間的最小值...示例:A = {6, 1, 7, 5, 3}索引 0 和 1 之間的最小值為 1索引 2 和 3 之間的最小值為 5索引 0 和 4 之間的最小值為 1遍歷每個查詢的元素并找到最小值的明顯方法在性能方面是不夠的。我不知何故需要一次性存儲所需的信息,然后在恒定時間內回答查詢。所以算法不應該是二次的。需要比 O(N * M) 更好的東西。(N:數組大小,M:查詢數)我試過但找不到如何做到這一點。它一定是關于查找和存儲一些總和并以某種方式使用它們的東西。有任何想法嗎?謝謝閱讀。
查看完整描述

2 回答

?
飲歌長嘯

TA貢獻1951條經驗 獲得超3個贊

要考慮的兩個選項:

  1. 每個查詢 O(n) 預計算和 O(logn)

  2. O(nlogn) 預計算和每個查詢 O(1)

第一種方法是通過遞歸計算偶數位置的所有對的最小值,然后在 4 的倍數位置處所有 4,然后在所有 8 的倍數處所有 8,依此類推。然后,每當您想要訪問特定范圍的最小值時,您將其分解為您已經擁有的部分并計算其中的最小值。

例如,要找到元素 1..10 的最小值,請使用 1 和 2..3 和 4..7 以及 8..9 和 10 的最小值。

第二個方法是計算所有位置的所有對的最小值,然后是所有位置的所有 4,然后是所有位置的所有 8。當你有一個特定的范圍時,你將它構造為兩個部分的最小值并計算這兩個部分的最小值。

例如,要找到元素 1..10 的最小值,請使用最小值 1..8 和最小值 3..10。


查看完整回答
反對 回復 2022-07-27
?
慕容森

TA貢獻1853條經驗 獲得超18個贊

為每個問題制作一個“解決方案”、一個“最小值”和一個“最大值”

然后,當您傳遞到數組的下一個元素時,如果您達到問題的 Index==min,則解決方案=該索引的數量。只要您沒有達到最大值,您就可以將解決方案與該索引中的數字和實際解決方案進行比較。(好的,我在發布時意識到這是 n * m,抱歉)


查看完整回答
反對 回復 2022-07-27
  • 2 回答
  • 0 關注
  • 119 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號