国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

[TsinsenA1490] osu!(喬明達(dá))

2019-11-10 19:05:53
字體:
供稿:網(wǎng)友

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

題意

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

題解

這是出題人的題解

下面簡(jiǎn)述此題解內(nèi)容。

分值的計(jì)算為∑mi=1(L2i+Li+1)m為極大連續(xù)1子段的段數(shù),leni為第i段的長(zhǎng)度。

將其分為三部分分別計(jì)算期望:∑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 復(fù)雜度O(n)

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

E(S2)的計(jì)算 由于出現(xiàn)了平方,計(jì)算S2的期望并沒有計(jì)算S0S1那么簡(jiǎn)單。 定義兩個(gè)數(shù)列 {leni}{expi}leni表示{bi}構(gòu)成的01串最長(zhǎng)的全是1的后綴的長(zhǎng)度,expi表示{bi}構(gòu)成的01串S2的期望值。len0=0,exp0=0。 對(duì)于leni,如果bi=1,則leni=leni?1+1,否則leni=0,故 leni=ai(leni?1+1)+(1?ai)?0=ai(leni?1+1) 對(duì)于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) 復(fù)雜度O(n)

用線段樹維護(hù)信息與查詢

維護(hù)S1 S1=L.S1+R.S1

維護(hù)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 故記錄區(qū)間左右端點(diǎn)的ai值就可以維護(hù)S0了。

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

復(fù)雜度O(n+mlogn)

這道題還有個(gè)簡(jiǎn)化版本,在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(),
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 阿尔山市| 新田县| 攀枝花市| 耿马| 武陟县| 保山市| 大关县| 盐边县| 新宁县| 丰城市| 永年县| 新平| 竹山县| 北辰区| 海盐县| 桑日县| 阿拉善盟| 永丰县| 九寨沟县| 营山县| 沐川县| 高唐县| 湘潭县| 象州县| 宾阳县| 靖安县| 平安县| 凤山县| 南宫市| 娄底市| 勃利县| 昌吉市| 大余县| 英山县| 台东县| 射阳县| 临沂市| 湖南省| 兴城市| 连江县| 曲阜市|