青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

算法學(xué)社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
1. 漲了25pt...

A

給500,000個(gè)字符串,如果兩個(gè)字符串的首字母和尾字母相連就說(shuō)明這兩個(gè)字符串相連。請(qǐng)問(wèn)可以組成的最長(zhǎng)環(huán)是多少...
分析:
一開(kāi)始我看這不是求最長(zhǎng)歐拉回路么...
后來(lái)發(fā)現(xiàn)一個(gè)條件: 只能前面的串去連后面的串,然后最后的串與第一個(gè)串相連... 但是當(dāng)時(shí)沒(méi)有想清楚...

B

在一個(gè)長(zhǎng)度小于100,000的數(shù)列{S}中,挑選K(K<100,000)個(gè)數(shù),讓這K個(gè)數(shù)大于B且最左端的數(shù)Si的i值最小....
分析:
從右到左掃一遍... 每次假設(shè)選中了Si,且維護(hù)一下右邊數(shù)列第k-1大的值,用優(yōu)先級(jí)隊(duì)列搞。
代碼
 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<queue>
 4 #include<iostream>
 5 using namespace std;
 6 typedef long long ll;
 7 int num[100005];
 8 priority_queue <int,vector<int>,greater<int>  > Q;
 9 int main(){
10     ll b;int n,k;
11     while(cin >> n >> k){
12         cin >>b;
13         for(int i=0;i<n;i++)
14             cin >>num[i];
15         ll sum = 0;
16         int ans = n;
17         n--;
18         while(!Q.empty())Q.pop();
19         for(int i = n-k+1; i<n; i++){
20             if(i < 0) continue;
21             sum += num[i];
22             Q.push(num[i]);
23         }
24         for(int i = n-k;i>=0; i--){
25 //            cout<<sum<<endl;
26             sum+= num[i];
27             Q.push(num[i]);
28 //            cout<<i<<" "<<sum<<endl;
29 //            cout<<Q.top()<<endl;
30             if(sum > b) ans = i+1;
31             if(sum-Q.top() > b) {
32                 ans = 1;
33                 break;
34             }
35             sum -= Q.top();
36             Q.pop();
37         }
38         cout<<ans<<endl;
39     }
40 }
41 

C

給一個(gè)點(diǎn)數(shù)為100,000的樹(shù),每次詢問(wèn)可以將u和v之間的路的每條邊權(quán)加1。最后請(qǐng)輸出所有邊的邊權(quán)。
分析:
動(dòng)態(tài)樹(shù)和樹(shù)鏈剖分都可,其實(shí)還有更簡(jiǎn)單的方法。不過(guò)沒(méi)時(shí)間想了... 直接甩模板了
樹(shù)鏈剖分版本:
  1 // template
  2 #include<iostream>
  3 #include<algorithm>
  4 #include<cassert>
  5 #include<cstdio>
  6 #include<cstdlib>
  7 #include<cstring>
  8 using namespace std;
  9 template <typename T> inline void chkmax(T &a, T b){if(a<b) a=b;}
 10 // graph
 11 const int V = 100005;
 12 const int E = 200005;
 13 int head[V],pnt[E],nxt[E],flag[E];
 14 int n,e;
 15 void addedge(int u,int v){
 16     nxt[e] = head[u];
 17     pnt[e] = v;
 18     head[u] = e;
 19     e ++;
 20 }
 21 // dsu 
 22 int parent[V];
 23 int find(int x){ return x == parent[x] ? x : parent[x] = find(parent[x]);}
 24 // seg_ment tree
 25 int seg[V<<2], M;
 26 void find(int l,int r){
 27     //cout<<l<<" "<<r<<endl;
 28     for(l += M-1, r += M+1; l^r^1; l>>=1, r>>=1){
 29         if(~l&1) seg[l^1]++;
 30         if(r&1) seg[r^1]++;
 31     }
 32 }
 33 // prepare
 34 int deep[V],size[V],heavy[V],P[V];
 35 void dfs(int u,int f){
 36     size[u] = 1;
 37     int mx = 0, s = -1;
 38     for(int i=head[u]; i!=-1;i = nxt[i]){
 39         if( pnt[i] == f) continue;
 40         int v = pnt[i];
 41         P[v] = i^1;
 42         deep[v] = deep[u] + 1;
 43         dfs(v,u);
 44         if(size[v] > mx){
 45             mx = size[v];
 46             s = i;
 47         }
 48         size[u] += size[v];
 49     }
 50     heavy[u] = s;
 51     if(s!=-1) parent[pnt[s]] = u;
 52 }
 53 void prepare(){
 54     for(int i=0;i<n;i++) parent[i] = i;
 55     deep[0] = 0;
 56     P[0] = -1;
 57     dfs(0,0);
 58     for(int i=30;i;i--) if((1<<i) > n+1) M = 1<<i;
 59     for(int i=0;i<2*M;i++) seg[i] = 0;
 60     int len = 1;
 61     for(int u = 0; u<n; u++) if(heavy[u] == -1){
 62         int v = u;
 63         while(v && pnt[heavy[pnt[P[v]]]] == v){
 64             flag[P[v]] = flag[P[v]^1] = len ++;
 65             v = pnt[P[v]];
 66         }
 67     }
 68 }
 69 // operator
 70 int lca(int u,int v){
 71     while(1){
 72         int a = find(u), b = find(v);
 73         if(a == b) return deep[u]<deep[v] ? u : v;
 74         else if(deep[a] > deep[b]) u = pnt[P[a]];
 75         else v = pnt[P[b]];
 76     }
 77 }
 78 int cnt[E];
 79 void query(int u,int v){
 80     //cout<<"query: "<<u<<" "<<v<<endl; 
 81     while(u != v){
 82         int l = P[u];
 83         if(pnt[heavy[pnt[P[u]]]] == u){
 84             int p = find(u);
 85             if(deep[p] < deep[v]) p = v;
 86             int r = heavy[p];
 87             assert(flag[l] <= flag[r]);
 88             find(flag[l],flag[r]);
 89             u = p;
 90         }
 91         else {
 92             u = pnt[l];
 93             cnt[l]++; cnt[l^1]++;
 94 //            cout<<l<<endl;
 95         }
 96     }
 97 }
 98 void ask(int a,int b){
 99     int p = lca(a,b);
100 //    cout<<a<<" "<<b<<" "<<p<<endl;
101     query(a,p); query(b,p);
102 }
103 // main
104 int main(){
105     int k;
106     while(~scanf("%d",&n)){
107         e = 0;
108         memset(head,-1,sizeof(head));
109         memset(cnt,0,sizeof(cnt));
110         for(int i=0;i<n-1;i++){
111             int u,v;
112             scanf("%d%d",&u,&v);
113             u--; v--;
114             addedge(u,v);
115             addedge(v,u);
116         }
117         prepare();
118         cin >>k;
119         while(k--){
120             int u,v;
121             scanf("%d%d",&u,&v);
122             u--;v--;
123             ask(u,v);
124         }
125         for(int i=0;i<e;i+=2){
126             int v = pnt[i], u = pnt[i^1];
127             if(heavy[v]!=(i^1) && heavy[u]!=i){
128                 cout<<cnt[i]<<" ";
129             }
130             else {
131                 int pos = flag[i]+M,ans = 0;
132                 while(pos) {ans += seg[pos]; pos >>=1;}
133                 cout<<ans<<" ";
134             }
135         }
136         cout<<endl;
137     }
138 }
139 
posted on 2012-05-28 09:07 西月弦 閱讀(801) 評(píng)論(8)  編輯 收藏 引用 所屬分類: 比賽感言

FeedBack:
# re: codeforces #121 div1 [未登錄](méi)
2012-05-28 23:09 | David
你好,請(qǐng)問(wèn)有沒(méi)有詳解動(dòng)態(tài)樹(shù)或樹(shù)鏈剖分的論文?  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-05-29 09:31 | 西月弦
http://fanhq666.blog.163.com/blog/static/819434262011518104215977/
動(dòng)態(tài)樹(shù)
樹(shù)鏈剖分看這篇論文
漆子超《分治算法在樹(shù)的路徑問(wèn)題中的應(yīng)用》
@David  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1 [未登錄](méi)
2012-05-30 00:10 | David
@西月弦
非常感謝!  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-06-27 13:05 | 蒟蒻
請(qǐng)問(wèn)C動(dòng)態(tài)樹(shù)怎么整...?大牛能否給個(gè)思路...link cut tree剛學(xué),不會(huì)維護(hù)區(qū)間和之類的...  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-06-27 14:43 | 西月弦
@蒟蒻
不好意思,我不會(huì)LCT...  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-06-27 19:14 | 蒟蒻
@西月弦
謝謝...大牛的樹(shù)鏈剖分的模版在哪找的...自己寫(xiě)的嗎?

  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-06-27 19:36 | 西月弦
@蒟蒻
恩,自己寫(xiě)的,比較丑額。。。。  回復(fù)  更多評(píng)論
  
# re: codeforces #121 div1
2012-06-28 12:39 | 蒟蒻
@西月弦
謝謝...  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区免费| 在线观看亚洲精品视频| 午夜在线观看欧美| 亚洲一区二区高清| 亚洲视频在线免费观看| 亚洲自拍偷拍色片视频| 欧美在线观看一区二区三区| 欧美亚洲专区| 裸体素人女欧美日韩| 免费中文日韩| 国产精品高潮呻吟久久av无限 | 欧美精品一区三区| 欧美日韩高清在线| 国产精品一卡二| 一区免费观看| 一区二区高清在线观看| 欧美一区二区视频免费观看| 另类酷文…触手系列精品集v1小说| 免费永久网站黄欧美| 亚洲精品在线视频| 久久成人国产| 欧美系列亚洲系列| 在线播放亚洲| 午夜亚洲激情| 91久久久久| 午夜精品久久| 欧美日韩喷水| 亚洲第一二三四五区| 亚洲私人影院在线观看| 美国三级日本三级久久99| 欧美精品v国产精品v日韩精品| 欧美日韩一区二区三区免费看 | 亚洲一区综合| 欧美11—12娇小xxxx| 国产嫩草一区二区三区在线观看 | 亚洲另类黄色| 久久久久综合网| 99国产精品国产精品毛片| 久久国产精品亚洲77777| 欧美日韩综合网| 91久久久一线二线三线品牌| 欧美一区二区三区免费观看视频| 亚洲国产欧美日韩精品| 久久riav二区三区| 国产乱人伦精品一区二区| 夜夜精品视频一区二区| 亚洲成人在线视频网站| 久久xxxx| 国内精品伊人久久久久av一坑| 一区二区久久久久| 亚洲黄色毛片| 欧美国产日本| 亚洲精品极品| 最新精品在线| 欧美精品乱码久久久久久按摩| 亚洲国产婷婷香蕉久久久久久| 久久综合久久综合九色| 久久国产直播| 伊人色综合久久天天五月婷| 久久久久国产精品人| 亚洲欧美日韩国产成人| 国产日韩欧美不卡在线| 久久精品久久99精品久久| 午夜精彩国产免费不卡不顿大片| 国产精品视频福利| 久久激情一区| 久久综合精品国产一区二区三区| 精品不卡一区| 亚洲第一视频网站| 欧美精品免费视频| 亚洲午夜日本在线观看| 这里只有视频精品| 国产欧美日韩视频一区二区三区| 久久av一区二区三区漫画| 在线看片欧美| 免费观看久久久4p| 欧美黄色aaaa| 午夜精品久久久久久久久久久久久| 亚洲影视在线播放| 国语自产精品视频在线看抢先版结局| 久久久久久伊人| 欧美成人激情在线| 亚洲一区二区三区免费观看| 亚洲欧美日韩精品久久奇米色影视| 国产婷婷一区二区| 女生裸体视频一区二区三区| 欧美日本一道本| 久久国产精品久久国产精品| 久久在线免费观看| 亚洲手机成人高清视频| 久久精品国产亚洲一区二区三区| 蜜臀av在线播放一区二区三区| 一二美女精品欧洲| 国产一区二区电影在线观看| 免费国产一区二区| 国产精品欧美日韩一区| 欧美丰满高潮xxxx喷水动漫| 国产精品成人一区二区三区吃奶 | 亚洲精品黄色| 国产精品色婷婷| 欧美福利视频一区| 国产精品视频精品视频| 亚洲欧洲精品天堂一级| 国产一区二区三区四区五区美女| 亚洲电影免费| 国产一区二区在线观看免费播放 | 欧美久久久久久久久| 欧美一区亚洲一区| 欧美精品日韩三级| 欧美1区2区视频| 国产欧美日韩三区| 一本色道久久综合精品竹菊| 亚洲黄色性网站| 久久精品综合| 久久久久久久精| 国产精品色午夜在线观看| 亚洲精品在线观看视频| 最新亚洲一区| 免费观看亚洲视频大全| 欧美在线观看一区| 欧美区一区二区三区| 欧美高清视频www夜色资源网| 国产色爱av资源综合区| 亚洲午夜精品久久久久久app| 亚洲精品久久久久| 91久久精品一区二区三区| 久久精品亚洲一区| 久久国产黑丝| 国产日韩欧美一区| 亚洲欧美影院| 久久久久久亚洲精品杨幂换脸| 国产精品视频999| 亚洲欧美国产精品桃花| 亚洲欧美视频| 国产日韩亚洲| 久久精品国产77777蜜臀 | 午夜精品99久久免费| 欧美精品三级日韩久久| 亚洲国产精品成人精品| 最新国产乱人伦偷精品免费网站| 老司机免费视频久久| 欧美电影免费观看高清| 亚洲精品少妇网址| 欧美日韩激情网| 亚洲自拍都市欧美小说| 久久精品国产久精国产一老狼 | 狠狠狠色丁香婷婷综合激情| 欧美一区午夜精品| 久久久久国内| 亚洲第一在线综合在线| 欧美激情女人20p| 亚洲一区二区三区高清不卡| 国语自产偷拍精品视频偷| 欧美一级淫片aaaaaaa视频| 久久久久久亚洲精品不卡4k岛国| 狠狠色伊人亚洲综合网站色| 久久精品国产久精国产思思| 蜜臀久久99精品久久久久久9| 91久久中文| 国产精品国产三级国产专播品爱网 | 欧美欧美全黄| 一区二区三区毛片| 久久乐国产精品| 亚洲每日更新| 国产视频欧美视频| 欧美成人乱码一区二区三区| 洋洋av久久久久久久一区| 久久高清免费观看| 亚洲美女电影在线| 国产人成一区二区三区影院| 欧美成人一区二区三区在线观看| 一区二区三区欧美视频| 麻豆精品视频在线观看| 亚洲视频在线观看| 欧美激情一区二区三区蜜桃视频| 在线综合亚洲欧美在线视频| 国产亚洲综合性久久久影院| 欧美高潮视频| 欧美一级免费视频| 亚洲精品1区| 久久亚洲春色中文字幕| 亚洲素人在线| 亚洲国产综合在线| 国产女主播一区二区| 欧美大片一区二区| 久久九九99视频| 亚洲在线一区| 99re66热这里只有精品3直播| 老司机免费视频一区二区| 亚洲午夜av在线| 亚洲人成网站777色婷婷| 国产视频一区三区| 国产精品视频久久久| 欧美色综合网| 欧美高清在线| 欧美波霸影院| 美国成人直播| 美日韩丰满少妇在线观看| 久久久久久网站| 久久久精品国产免费观看同学|