亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

[TsinsenA1490] osu!(喬明達)

2019-11-10 19:05:53
字體:
來源:轉載
供稿:網友

作為一名osu!玩家,這道題成功吸引到了我。。。

題意

長度為n的序列,給出每一個數字可能為1的概率ai,每個數字為0的概率為1?ai。兩個操作:修改某個數字的概率,詢問一段區間得分期望,得分計算方式如下。 將玩家完成一張地圖的01串中所有的0刪去,則這個串可能會斷裂成若干段連續的1。對于一段長度為L1(L≥1),你的總分會增加L2+L+1。例如:一張地圖有10個音,某玩家完成情況為1011101110,則刪除所有0后得到的是“1”“111”和“111”。因此這個玩家的得分為(1+1+1)+(9+3+1)+(9+3+1)=29。

題解

這是出題人的題解

下面簡述此題解內容。

分值的計算為∑mi=1(L2i+Li+1),m為極大連續1子段的段數,leni為第i段的長度。

將其分為三部分分別計算期望:∑L2i,∑Li∑1。將這三部分分別記為S2,S1S0。記01串第i位為bi,則bi=1概率為aibi=0概率1?ai。

S1的期望 E(S1)=E(∑i=1nbi)=∑i=1nE(bi)=∑i=1nai 復雜度O(n)

S0的期望 S0的實際意義是01串中極大1字段的個數。關注每個這樣子串的起始位置,這樣的位置和子串是一一對應的,只需要統計有多少位置是子串的起始位置。 考慮第i位,它是起始位置當且僅當第i位是1,第i?1位是0。特別地,規定第0位一定是0,即a0=0。因此第i位是起始位置的概率為ai(1?ai?1)E(S0)=E(∑i=1nai(1?ai?1)) 復雜度O(n)

E(S2)的計算 由于出現了平方,計算S2的期望并沒有計算S0S1那么簡單。 定義兩個數列 {leni}{expi},leni表示{bi}構成的01串最長的全是1的后綴的長度,expi表示{bi}構成的01串S2的期望值。len0=0,exp0=0。 對于leni,如果bi=1,則leni=leni?1+1,否則leni=0,故 leni=ai(leni?1+1)+(1?ai)?0=ai(leni?1+1) 對于expi,如果bi=1,Δ=(leni?1+1)2?len2i?1=2leni?1+1,否則Δ=0,故 expi=expi?1+ai(2leni?1+1)+(1?ai)?0=expi?1+ai(2leni?1+1) 復雜度O(n)

用線段樹維護信息與查詢

維護S1 S1=L.S1+R.S1

維護S0Lai值分別為a,b,c,Rai值分別為d,e,f. L.S0=a+b(1?a)+c(1?b) R.S0=d+e(1+d)+f(1?e) S0=a+b(1?a)+c(1?b)+d(1?c)+e(1?d)+f(1?e)=L.S0+R.S0?cd 故記錄區間左右端點的ai值就可以維護S0了。

維護S2 leni=aileni?1+ai expi=expi?1+2aileni?1+ai 這是一個線性變換,表示矩陣為 T=???ai0ai2ai1ai001??? (leni?1,expi?1,1)?T=(leni,expi,1) 所以拿(0,0,1)去乘一整個區間的矩陣就能得到(lenk,expk,1),k為區間長度,expkS2的答案。 這道題沒有區間修改不用打標記,每個區間直接記錄矩陣,由于矩陣乘法的結合律,可以用線段樹維護區間的矩陣乘積。但是直接這么寫常數太大。 觀察T???a0cb1d001??????e0gf1h001???=???ae0ce+gaf?b1cf+d+h001??? 可以看到一個矩陣我們只需記錄四個值即可,大大減小了常數。

復雜度O(n+mlogn)

這道題還有個簡化版本,在BZOJ4318,給出PO姐的題解

代碼

/// by ztx/// blog.csdn.net/hzoi_ztx#define Rep(i,l,r) for(i=(l);i<=(r);i++)#define rep(i,l,r) for(i=(l);i< (r);i++)#define Rev(i,r,l) for(i=(r);i>=(l);i--)#define rev(i,r,l) for(i=(r);i> (l);i--)#define Each(i,v) for(i=v.begin();i!=v.end();i++)typedef long long ll ;typedef double lf ;int CH , NEG ;template <typename TP>inline void read(TP& ret) { ret = NEG = 0 ; while (CH=getchar() , CH<'!') ; if (CH == '-') NEG = true , CH = getchar() ; while (ret = ret*10+CH-'0' , CH=getchar() , CH>'!') ; if (NEG) ret = -ret ;}#define kN 500010LL#define kT 2000010LL#define M ((L+R)/2)#define l(o) (o<<1)#define r(o) (o<<1|1)#define left l(o),L,M#define right r(o),M+1,Rstruct mat { lf x[4]; };inline mat Mul(const mat&a,const mat&b) { return (mat){a.x[0]*b.x[0],a.x[0]*b.x[1]+a.x[1],a.x[2]*b.x[0]+b.x[2],a.x[2]*b.x[1]+a.x[3]+b.x[3]};}inline void One(mat&a) { a.x[0] = 1.0, a.x[1] = a.x[2] = a.x[3] = 0;}inline lf Ans(const mat&a) { return a.x[3];// (0,0,1) * (a b 0) = (c,d,1)// (0 1 0) ^// (c d 1)}int n, ql, qr;lf a[kN], qw, qa0, qa1, qra;mat qa2;lf s0[kT], s1[kT], la[kT], ra[kT];mat t[kT];void update(int o) { la[o] = la[l(o)], ra[o] = ra[r(o)]; s0[o] = s0[l(o)]+s0[r(o)]-ra[l(o)]*la[r(o)]; s1[o] = s1[l(o)]+s1[r(o)]; t[o] = Mul(t[l(o)],t[r(o)]);}void Build(int o=1, int L=1, int R=n) { if (L == R) { t[o].x[0] = t[o].x[2] = t[o].x[3] = a[L], t[o].x[1] = a[L]*2; la[o] = ra[o] = s0[o] = s1[o] = a[L]; return ; } Build(left), Build(right); update(o);}void Modify(int o=1, int L=1, int R=n) { if (L == R) { a[L] = qw; t[o].x[0] = t[o].x[2] = t[o].x[3] = qw, t[o].x[1] = qw*2; la[o] = ra[o] = s0[o] = s1[o] = qw; return ; } if (ql <= M) Modify(left); else Modify(right); update(o);}void Query(int o=1, int L=1, int R=n) { if (ql<=L && R<=qr) { qa0 += s0[o]-qra*la[o], qra = ra[o]; qa1 += s1[o]; qa2 = Mul(qa2,t[o]); return ; } if (ql <= M) Query(left); if (qr > M) Query(right);}#undef r#define r(x) read(x)int main() { int m, i, ope; r(n), r(m); Rep (i,1,n) scanf("%lf", &a[i]); Build(); while (m --> 0) { r(ope); if (ope) r(ql), scanf("%lf", &qw), Modify(); else r(ql), r(qr), qa0=qa1=qra=0, One(qa2), Query(),
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区美女视频在线观看免费| 日韩国产激情在线| 91大神在线播放精品| 色爱精品视频一区| 亚洲视频欧美视频| 中文字幕日韩欧美在线视频| 麻豆国产va免费精品高清在线| 日韩在线观看免费全集电视剧网站| 精品香蕉一区二区三区| 久久精品国产v日韩v亚洲| 91精品国产91久久久久久| 亚洲精品视频久久| 国产精品久久久久久av福利| 26uuu日韩精品一区二区| 91精品国产自产在线老师啪| 在线视频免费一区二区| 精品国偷自产在线| 中文字幕国产日韩| 欧美电影院免费观看| 亚洲性线免费观看视频成熟| 日本一本a高清免费不卡| 国产精品嫩草视频| 亚洲国产精品99久久| 97视频在线看| 成人久久精品视频| 日韩精品黄色网| 欧美性xxxxxxxxx| 国产精品影片在线观看| 亚洲精品成人久久电影| 精品久久久久久久久久ntr影视| 欧美视频国产精品| 欧美天堂在线观看| 亚洲视频专区在线| 亚洲人高潮女人毛茸茸| 国产精品美女呻吟| 岛国av午夜精品| 国内精品一区二区三区四区| 97精品国产97久久久久久免费| 久久夜色撩人精品| 黑人巨大精品欧美一区二区一视频| 中文字幕在线亚洲| 久久在线观看视频| 欧洲一区二区视频| 国产精品无av码在线观看| 精品久久久国产精品999| 亚洲偷熟乱区亚洲香蕉av| 精品呦交小u女在线| 亚洲国产又黄又爽女人高潮的| 精品久久久久久久大神国产| 精品久久香蕉国产线看观看亚洲| 欧美丝袜一区二区三区| 国产高清视频一区三区| 久久免费成人精品视频| 精品视频在线播放色网色视频| 欧美又大又硬又粗bbbbb| 日韩美女视频免费在线观看| 成人美女免费网站视频| 亚洲精品中文字幕有码专区| 国产欧美一区二区三区视频| 国产精品久久久一区| 日韩在线免费高清视频| www国产精品com| 久久精品久久久久| 精品国偷自产在线| 国产99视频精品免视看7| 亚洲一区二区自拍| 中文字幕国产亚洲| 国产精品美女www爽爽爽视频| 中文字幕日韩在线视频| 91精品国产综合久久香蕉922| 高跟丝袜欧美一区| 国产精品国产自产拍高清av水多| 国产日韩欧美视频在线| 国产精品亚洲一区二区三区| 亚洲欧美日韩中文在线制服| 91精品久久久久久久久久久久久| 欧美xxxx18国产| 亚洲性线免费观看视频成熟| 国产91精品视频在线观看| 国产精品久久婷婷六月丁香| 日韩亚洲国产中文字幕| 亚洲欧洲在线播放| 国产精品视频永久免费播放| www.亚洲人.com| 久久免费视频在线| 亚洲影院色在线观看免费| 日韩精品极品视频免费观看| 日韩性生活视频| 亚洲精品一区二区久| 中文字幕亚洲无线码a| 亚洲精品久久久一区二区三区| 精品无人区太爽高潮在线播放| 在线播放国产一区二区三区| 精品成人久久av| 国产精品久久久久久久久久久久| 精品露脸国产偷人在视频| 欧美日韩国产限制| 欧美一级视频免费在线观看| 日韩精品免费视频| 亚洲美女视频网| 欧美特黄级在线| 久久久久久久国产精品| 日韩在线观看免费全| 日本精品视频在线播放| 久久91亚洲精品中文字幕| 欧美洲成人男女午夜视频| 亚洲成色777777在线观看影院| www.99久久热国产日韩欧美.com| 欧美电影免费观看高清| 日韩欧美在线观看| 欧美国产日韩一区二区在线观看| 国产精品国产福利国产秒拍| 国产日韩亚洲欧美| 国产精品v日韩精品| 久久国产视频网站| 成人av在线网址| 亚洲精品美女久久久久| 91夜夜揉人人捏人人添红杏| 亚洲人高潮女人毛茸茸| 亚洲国产精品小视频| 在线激情影院一区| 欧美最顶级的aⅴ艳星| 国产一区二区三区在线观看视频| 欧美极品少妇xxxxⅹ喷水| 欧美一级在线亚洲天堂| 日韩av成人在线观看| 欧美在线一级va免费观看| 欧美肥臀大乳一区二区免费视频| 精品爽片免费看久久| 亚洲乱码一区二区| 91网在线免费观看| 欧美制服第一页| 欧洲成人免费aa| 98视频在线噜噜噜国产| 日韩精品视频免费在线观看| 中文字幕在线看视频国产欧美在线看完整| 欧美亚洲成人精品| 欧美精品精品精品精品免费| 91色视频在线观看| 亚洲一区国产精品| 久久精品国产69国产精品亚洲| 麻豆成人在线看| 亚洲91精品在线| 国产精品久久久久久久一区探花| 久久久久久久久电影| 欧美精品精品精品精品免费| 亚洲美女在线视频| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲成人亚洲激情| 欧美高清激情视频| 欧美电影免费观看大全| 国模精品一区二区三区色天香| 国产91热爆ts人妖在线| 国产日本欧美一区二区三区在线| 国产一区二区黄| 亚洲xxxx妇黄裸体| 亚州av一区二区| 日韩欧美国产黄色| 国产第一区电影| 懂色av影视一区二区三区| 亚洲一区二区国产| 91网站在线看| 免费不卡在线观看av| 亚洲第一视频网|