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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

『ACM-算法-ST算法』信息竞赛进阶指南--区间最值问题的ST算法

發布時間:2023/12/15 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 『ACM-算法-ST算法』信息竞赛进阶指南--区间最值问题的ST算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

借助倍增和動態規劃可以實現O(1)的時間復雜度的查詢

預處理:
①區間DP 轉移方程 f[i][j] = min(MAX同理)(f[i][j - 1],f[i + ][j - 1]) f[i][j]表示從i位置開始的后2^j個數中的最大值

用f[i][j]表示從j到j+2i-1的最小值(長度顯然為2i)。
任意一段的最小值顯然等于min(前半段最小值,后半段最小值)。
那么f[i][j]如何用其他狀態來繼承呢?
j到j+2i-1的長度為2i,那么一半的長度就等于2^(i-1)。
那么前半段的狀態表示為f[i-1][j]。
后半段的長度也為2(i-1),起始位置為j+2(i-1)。
那么后半段的狀態表示為f[i-1][j+2^(i-1)]。

②不過區間在增加時,每次并不是增加一個長度,而是基于倍增思想,用二進制右移,每次增加2^i個長度 ,最多增加logn次

這樣預處理了所有2的冪次的小區間的最值

查詢:
③對于每個區間,分成兩段長度為的區間,再取個最值(這里的兩個區間是可以有交集的,因為重復區間并不影響最值)

比如3,4,6,5,3一種分成3,4,6和6,5,3,另一種分成3,4,6和5,3,最大值都是6,沒影響。

首先明確 2^log(a)>a/2
這個很簡單,因為log(a)表示小于等于a的2的最大幾次方。比如說log(4)=2,log(5)=2,log(6)=2,log(7)=2,log(8)=3,log(9)=3…….
那么我們要查詢x到y的最小值。設len=y-x+1,t=log(len),根據上面的定理:2t>len/2,從位置上來說,x+2t越過了x到y的中間!
因為位置過了一半,所以x到y的最小值可以表示為min(從x往后2t的最小值,從y往前2t的最小值),前面的狀態表示為f[t][x]
設后面(從y往前2t的最小值)的初始位置是k,那么k+2t-1=y,所以k=y-2t+1,所以后面的狀態表示為f[t][y-2t+1]
所以x到y的最小值表示為f(f[t][x],f[t][y-2^t+1]),所以查詢時間復雜度是O(1)

④所以O(nlogn)預處理,O(1)查詢最值 但不支持修改
預處理時間復雜度O(nlogn),查詢時間O(1)。

void ST_prework() {for (int i = 1; i <= n; i++) f[i][0] = a[i];int t = log(n) / log(2) + 1;for (int j = 1; j < t; j++)for (int i = 1; i <= n - (1<<j) + 1; i++)f[i][j] = max(f[i][j-1], f[i + (1<<(j-1))][j-1]); }int ST_query(int l, int r) {int k = log(r - l + 1) / log(2);return max(f[l][k], f[r - (1<<k) + 1][k]); }

總結

以上是生活随笔為你收集整理的『ACM-算法-ST算法』信息竞赛进阶指南--区间最值问题的ST算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。