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

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

Codeforces 766E Mahmoud and a xor trip [二進(jìn)制,]【數(shù)學(xué)+思維】

2019-11-09 21:15:48
字體:
供稿:網(wǎng)友

題目連接:http://codeforces.com/contest/766/PRoblem/E ——————————————————————————. ——————————————————————————. 題目大意: 就是在一個(gè)生成樹上求任意兩點(diǎn)的距離的和,距離定義為兩點(diǎn)間路上所有點(diǎn)權(quán)值的異或和,

解題思路:

想法就是將結(jié)果的異或和拆分成每一位的,就是對于二進(jìn)制數(shù)上對于第i位,有多少個(gè)距離為1的路徑,然后在總結(jié)果上+路徑數(shù)(1<<i)即可,這樣最多按二進(jìn)制位數(shù)個(gè)的搜索一遍樹就行了. cnt[][0]是以u為根0的個(gè)數(shù),cnt[][1]同理.

聽聞這題還有樹分治和數(shù)dp的做法,有興趣可以百度一發(fā).

附本題代碼 ——————————————————————————.

int a[N],b[N],cnt[N][2];vector<int >E[N];LL sum ;void dfs(int u,int fa){ cnt[u][0]=cnt[u][1]=0; cnt[u][b[u]]++; sum+=b[u]; int v; for(int i=0;i<E[u].size();i++){ v = E[u][i]; if(v==fa) continue; dfs(v,u); sum+=cnt[u][0]*cnt[v][1]+cnt[u][1]*cnt[v][0]; cnt[u][b[u]]+=cnt[v][0]; cnt[u][b[u]^1]+=cnt[v][1]; }}int main(){ int n,u,v; n = read(); Rep(i,1,n) a[i]=read(),E[i].clear(); Rep(i,2,n){ u=read(),v=read(); E[u].pb(v); E[v].pb(u); } LL ans = 0ll; Rep(i,0,20){ Rep(j,1,n){ if(a[j]&(1<<i)) b[j]=1; else b[j]=0; } sum = 0ll; dfs(1,-1); ans += sum*(1<<i); } printf("%I64d/n",ans); return 0;}

對于對樹、圖進(jìn)行dfs的要好好練練 總是搜不明白.


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 简阳市| 宁都县| 武冈市| 溧阳市| 彩票| 泸西县| 多伦县| 奎屯市| 扎囊县| 淮阳县| 乌鲁木齐市| 江陵县| 灵宝市| 会宁县| 项城市| 三门县| 阿坝| 财经| 福建省| 舞阳县| 婺源县| 明水县| 肥城市| 乐山市| 河南省| 凯里市| 遂平县| 昭平县| 昭苏县| 当涂县| 常山县| 南通市| 永善县| 乌兰察布市| 恩施市| 荆州市| 澄江县| 阿克苏市| 深州市| 玉溪市| 九寨沟县|