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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

ST函数(ST表)RMQ O(1)查询 离线

發布時間:2023/12/15 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ST函数(ST表)RMQ O(1)查询 离线 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ST算法是基于倍增的動態規劃算法。

?

#include<iostream> #include<cstdio> #include<cstdlib> #include<cmath> using namespace std; int map[1000005][20]; int N,K; void work() {int i,j;for(j=1;1<<j<=N;j++)for(i=1;i+(1<<j)-1<=N;i++)//i+(1<<j)-1<=n是為了保證區間左端點不超出總數nmap[i][j]=min(map[i][j-1],map[i+(1<<j-1)][j-1]);//實質是動態規劃 } int question(int z,int y) {int x=int (log(y-z+1)/log(2));//注意y-z要加一才為區間長度return min(map[z][x],map[y-(1<<x)+1][x]);//分別以左右兩個端點為基礎,向區間內跳1<<x的最 //大值; } int main() {scanf("%d",&N);//輸入數據總數scanf("%d",&K);//輸入詢問次數kfor(int i=1;i<=N;i++)scanf("%d",&map[i][0]);//數據輸入加初始化,即從i開始向右走2的0次方的區間中的最大值,(注//意i到i的長度為一)。work();//預處理for(int i=1;i<=K;i++){int a,b;scanf("%d%d",&a,&b);printf("%d ",question(a,b));//輸出結果}return 0; }

?

總結

以上是生活随笔為你收集整理的ST函数(ST表)RMQ O(1)查询 离线的全部內容,希望文章能夠幫你解決所遇到的問題。

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