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

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
300pt
    一個人在一個圖上行走,每次走邊權值最小的邊,如果有多個邊權最小的邊就選擇標號最小的。現在讓你修改某個邊權,請問如何才能讓這個人走的最多。
    邊權小于10000大于0。點數不超過30的完全圖。
算法分析:
    根據數據范圍可以確定,枚舉修改每條邊,強制讓那個人走這條邊就可以了。時間復雜度V^4。
    比賽的時候沒有看到邊權一定要大于0。結果悲劇了。
 1 #include<iostream>
 2 #include<string>
 3 #include<vector>
 4 #include<cstring>
 5 using namespace std;
 6 const int V = 60;
 7 int G[V][V],num[V];
 8 void chkmax(int &a,int b){
 9     if(a < b) a = b;
10 }
11 int vis[V],n;
12 int work(){
13     memset(vis,0,sizeof(vis));
14     int u = 0, ans = 0;
15     while(1){
16         vis[u] = 1;
17         int fst = -1, snd = -1, mx = 10000, mn = 10000;
18         for(int v = 0; v < n; v ++) if(!vis[v]){
19             if(G[u][v] < mn){
20                 mx = mn; snd = fst;
21                 mn = G[u][v]; fst = v;
22             }
23             else if(G[u][v] < mx){
24                 mx = G[u][v]; snd = v;
25             }
26         }
27         if(fst == -1) return ans;
28         int k = num[u];
29         if(vis[k]) return 0;
30         int val;
31         if(u==18 && num[u]==27){
32     //        cout<<fst<<" "<<snd<<endl;
33         //    cout<<mn<<" "<<mx<<endl;
34             
35         }
36         if(k == fst) {
37             if(snd == -1) val = 9999;
38             else val = mx - (k < snd ? 0 : 1);
39             u = fst;
40         }
41         else if(k == -1){
42             val = G[u][fst];
43             u = fst;
44         }
45         else {
46             val = G[u][fst] - (k < fst ? 0 : 1);
47             if(k == snd && !(mx == 9999 && fst < snd)){
48                 val = mx;
49             }
50             if(val == 0) return 0;
51             u = k;
52         }
53         ans += val;
54     }
55 }
56 class GreedyTravelingSalesman{
57     public : int worstDistance(vector <string> thousands, vector <string> hundreds, vector <string> tens, vector <string> ones){
58         n = ones.size();
59         for(int i=0;i<n;i++)
60             for(int j=0;j<n;j++)
61                 G[i][j] = (thousands[i][j]-'0')*1000+ (hundreds[i][j]-'0')*100 + (tens[i][j]-'0')*10 + (ones[i][j]-'0');
62         int ans = 0;
63         for(int i=0;i<n;i++)
64             for(int j=0;j<n;j++) {
65                 memset(num,-1,sizeof(num));
66                 num[i] = j;
67                 int v = work();
68                 chkmax(ans, v);
69                 //if(v == 40375 || v ==39896)cout<<i<<" "<<j<<" "<<v<<endl;
70             }
71         return ans;
72     }
73 };
500pt
    歐式平面上有N個點,(N<30,000)。橫縱坐標在0到1,000,000,000之間,且保證沒有x值或者y值相同的點。請問滿足x1<x2<x3 && y1<y3<y2的點一共有多少個?
算法分析:
    將橫坐標排序,從左到右掃描,檢查縱坐標。問題變成了點i之前有多少個yj>yi && yk<yi且j>k的點對。顯然離散化之后線段樹可以搞。
    我們按照從左到右的順序插入點。要維護三個值: 
        1. 區間[l,r]有多少個點。由此我們在插入i的時候就知道之前有多少個比i小的點了。
        2. 區間[l,r]有多少個以k為右上端點的線段。
        3. 區間[l,r]有多少個以k為左下端點的線段。
    在查詢的時候,對于比i大的區間[l,r],(值2-值3)就是這個區間里符合條件的線段數。都加上就好了。
    我們可以用值1來維護值2。用懶惰標記更新值3。
    寫起來還是比較容易寫錯的。
   upt: 磊哥教了我一個從右向左掃描動態求逆序數的方法 Orz!!!! 比這個好想很多也好寫很多。。。。。
 1 #include<iostream>
 2 #include<cstdlib>
 3 #include<algorithm>
 4 using namespace std;
 5 typedef long long ll;
 6 typedef pair<ll, ll> pnt;
 7 const int N = 300005;
 8 ll num[N<<2], sum[N<<2], hash[N], suma[N<<2] , ans, v;
 9 int chg[N<<2];
10 pnt flag[N];
11 int find(ll val, int n){
12     int l = 0, r = n;
13     while(l < r){
14         int mid = l+r >> 1;
15         if(hash[mid] >= val) r = mid;
16         else l = mid+ 1;
17     }
18     return l;
19 }
20 void pushdown(int pos){
21     if(chg[pos]){
22         int l = pos <<1, r = pos<<1 |1;
23         chg[l] += chg[pos];
24         chg[r] += chg[pos];
25         suma[l] += num[l] * chg[pos];
26         suma[r] += num[r] * chg[pos];
27         chg[pos] = 0;
28     }
29 }
30 void sumup(int pos){
31     int l = pos <<1; int r = pos<<1|1;
32     sum[pos] = sum[l] + sum[r];
33     num[pos] = num[l] + num[r];
34     suma[pos] = suma[l] + suma[r];
35 }
36 void update(int P,int pos, int L,int R){
37     if(L==R){
38     //    cout<<"v: "<<v<<endl;
39         sum[pos] += v;
40         num[pos] ++;
41         chg[pos] = 0;
42         return ;
43     }
44     pushdown(pos);
45     int mid = L+R>>1, l = pos <<1, r = pos<<1|1;
46     if(P <=mid) {
47     //    cout<<"left: "<<L<<" "<<R<<" "<<sum[r]<<" "<<suma[r]<<endl;
48         ans += sum[r] - suma[r];
49         update(P,l,L,mid);
50     }
51     else {
52         v += num[l];
53     //    cout<<"right: "<<v<<endl;
54         chg[l] ++; suma[l] += num[l];
55         update(P,r,mid+1,R);
56     }
57     sumup(pos);
58 //    cout<<"back: "<<pos<<" "<<L<<" "<<R<<" sum: "<<sum[pos]<<" num : "<<num[pos]<<endl;
59 }
60 class ThreePoints{
61     public :ll countColoring(int n, int xzero, int xmul, int xadd, int xmod, int yzero, int ymul, int yadd, int ymod){
62         flag[0] = make_pair(xzero, yzero);
63         hash[0] = yzero;
64         for(int i=1; i< n; i++){
65             ll x = (flag[i-1].first*xmul + xadd) % xmod ;
66             ll y = (flag[i-1].second*ymul + yadd) % ymod;
67             flag[i] = make_pair (x,y);
68             hash[i] = y;
69         }
70         sort(hash,hash+n);
71         sort(flag,flag+n);
72         //for(int i=0;i<n;i++) cout<<hash[i]<<" "; cout<<endl;
73         ans = 0;
74         for(int i=0; i< n; i++){
75         //    cout<<"pnt: "<<flag[i].first <<" "<<flag[i].second<<endl;
76             int P = find(flag[i].second,n);
77         //    cout<<"P: "<<P<<endl;
78             v = 0;
79             update(P,1,0,n-1);
80         //    cout<<"ans: "<<ans<<endl;
81         //    for(int i=1;i<=15;i++) cout<<num[i]<<" ";  cout<<endl;
82         }
83         return ans;
84     }
85 };
posted on 2012-06-17 13:19 西月弦 閱讀(303) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产va精品久久久不卡综合| 宅男噜噜噜66一区二区66| 在线视频亚洲一区| 亚洲国产一区二区三区青草影视 | 欧美精品国产一区| 久久精品国亚洲| 久久综合九色欧美综合狠狠| 亚洲欧美国产精品va在线观看| 欧美激情视频一区二区三区在线播放 | 国产一区二区三区直播精品电影 | 宅男噜噜噜66国产日韩在线观看| 欧美激情亚洲另类| 亚洲免费观看高清完整版在线观看| 亚洲国产高潮在线观看| 夜夜嗨av色一区二区不卡| 国产综合网站| 国产精品亚洲综合一区在线观看| 欧美视频免费看| 国产美女精品一区二区三区| 国产亚洲精品久久久久久| 在线不卡免费欧美| 99精品视频免费观看视频| 亚洲欧美一区二区在线观看| 性欧美大战久久久久久久免费观看| 欧美在线免费一级片| 亚洲激情亚洲| 99热免费精品| 另类av一区二区| 亚洲一区区二区| 欧美激情视频一区二区三区在线播放 | 99re6热在线精品视频播放速度| 亚洲视频观看| 国产精品高潮呻吟| 91久久国产自产拍夜夜嗨| 久久精品免费看| 亚洲欧美清纯在线制服| 欧美精品免费视频| 亚洲精品一区二区三区四区高清| 久久精品国产一区二区三区| 午夜一区不卡| 国产精品一区二区三区免费观看| 99re6热在线精品视频播放速度| 久久精品国产综合精品| 午夜精品国产| 狠狠色2019综合网| 美国成人直播| 蜜桃久久av一区| 亚洲一区999| 午夜一级在线看亚洲| 国内视频一区| 欧美激情视频一区二区三区不卡| 欧美成人69| 亚洲欧美中日韩| 在线亚洲一区| 欧美日韩在线不卡| aⅴ色国产欧美| 亚洲天堂男人| 伊人狠狠色j香婷婷综合| 亚洲第一偷拍| 国产精品亚洲综合色区韩国| 欧美成人中文字幕| 国产精品a久久久久久| 久久夜色精品国产欧美乱极品| 欧美在线国产| 亚洲一区二区三区高清| 久久精品五月婷婷| 午夜精品视频在线| 美日韩精品视频免费看| 午夜一区在线| 欧美日韩国产高清视频| 久久久久高清| 国产精品影视天天线| 亚洲国产一区二区三区高清| 国产一区二区三区日韩| 一本色道久久加勒比88综合| 91久久综合亚洲鲁鲁五月天| 亚洲一区二区伦理| 午夜电影亚洲| 国产精品日韩精品欧美精品| 亚洲国产婷婷| 一本色道久久加勒比88综合 | 一区二区高清在线观看| 久久综合狠狠综合久久综合88 | 在线观看一区二区精品视频| 午夜在线观看免费一区| 欧美专区在线| 亚洲破处大片| 欧美日韩成人综合| 永久久久久久| 欧美一区二区在线免费播放| 久久国产日韩| 亚洲精品欧美极品| 欧美日韩亚洲一区二区三区在线观看 | 亚洲黄色av一区| 日韩亚洲国产欧美| 久久一区二区三区超碰国产精品| 亚洲一区二区精品在线| 久久久午夜电影| 日韩网站免费观看| 国产精品任我爽爆在线播放 | 欧美在线免费一级片| 亚洲韩国青草视频| 国产精品免费一区二区三区在线观看| 亚洲一区二区在线看| 欧美黄色片免费观看| 欧美在线关看| 亚洲一级黄色片| 亚洲精品久久久久久久久| 国产欧美丝祙| 国产精品欧美日韩一区| 欧美精品在线视频| 欧美激情一区二区久久久| 久久久精品日韩| 亚洲欧美日韩成人| 亚洲欧美一区二区原创| 在线一区二区三区做爰视频网站 | 亚洲免费激情| 亚洲欧洲精品一区二区精品久久久| 亚洲精品三级| 亚洲深夜激情| 99视频在线观看一区三区| 午夜精品国产| 久久网站免费| 你懂的视频一区二区| 欧美激情免费在线| 欧美日韩中文| 国产伊人精品| 亚洲第一页在线| 亚洲精品视频中文字幕| 午夜精品久久久久久久男人的天堂 | 麻豆freexxxx性91精品| 久久在线免费观看| 欧美亚韩一区| 在线成人h网| 亚洲夜晚福利在线观看| 久久久中精品2020中文| 欧美激情性爽国产精品17p| 亚洲精品你懂的| 亚洲图片欧美日产| 久久美女性网| 国产精品三级视频| 亚洲欧洲一区二区在线观看| 麻豆免费精品视频| 久久国产直播| 欧美日韩在线看| 永久91嫩草亚洲精品人人| 亚洲欧美精品| 欧美日韩成人网| 亚洲精品一区二区网址| 欧美在线观看视频在线| 亚洲色图制服丝袜| 久久久久久9999| 国产午夜精品在线观看| 亚洲一区二区三区午夜| 在线视频欧美一区| 国产精品国产亚洲精品看不卡15 | 久久久97精品| 国产一区二区三区四区在线观看| 亚洲网友自拍| 中日韩美女免费视频网址在线观看 | 日韩一区二区高清| 亚洲激情在线播放| 欧美高清在线| 亚洲一区二区在线看| 99国产精品久久久| 久久激情综合网| 亚洲乱亚洲高清| 一区二区三区你懂的| 国产精品日日摸夜夜摸av| 久久频这里精品99香蕉| 免费亚洲电影| 亚洲综合国产| 久久综合色8888| 亚洲免费人成在线视频观看| 亚洲专区一区| 亚洲精品麻豆| 欧美一区1区三区3区公司| 精品成人乱色一区二区| 亚洲精品一区二区网址| 国产日韩欧美三级| 亚洲国产欧美不卡在线观看| 国产精品制服诱惑| 亚洲激情视频在线观看| 国产农村妇女毛片精品久久莱园子| 欧美成人国产| 狠狠入ady亚洲精品经典电影| 亚洲精品一区二区三区不| 亚洲电影观看| 欧美在线亚洲| 久久国产精品第一页| 欧美体内she精视频| 1000精品久久久久久久久| 欧美激情精品久久久久久久变态 | 亚洲午夜av电影| 亚洲精品影视| 欧美国产国产综合| 亚洲欧洲一区二区在线观看| 最新国产拍偷乱拍精品| 欧美不卡一区| 亚洲人成啪啪网站|