• <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>

            Why so serious? --[NKU]schindlerlee

            2010年03月28日星期日.codeforces beta6

            2010年03月28日星期日.codeforces beta6

            A:三角形兩邊之和大于第三邊
            B:暴力搜一下
            C:模擬

            ?1?
            ?2?scanf("%d\n",&n);
            ?3?for?(i?=?0;i?<?n;i++)?{
            ?4???scanf("%d",a?+?i);
            ?5?}
            ?6?int?L?=?0,R?=?n?-?1,time1?=?0,time2?=?0,ans1?=?0,ans2?=?0;
            ?7?while?(L?<=?R)?{
            ?8???if?(time1?<?time2)?{
            ?9???????time1?+=?a[L++]?,ans1?++;
            10???}else?if?(time1?>?time2)?{
            11???????time2?+=?a[R--]?,ans2?++;
            12???}else?{
            13???????time1?+=?a[L++]?,ans1?++;
            14???}
            15?}
            16?printf("%d?%d\n",ans1,ans2);

            D:題目改了,和比賽的時(shí)候不一樣了,數(shù)據(jù)范圍很小,dfs
            E:RMQ + binary_search
            給出n個(gè)數(shù)和一個(gè)范圍K。
            找出最長的連續(xù)的數(shù),其中最大值和最小值的差不超過K
            一個(gè)直覺的想法是
            for(i = 0;i < n;i++) {
            ?? ?int L = a[i],R = a[i];
            ?? ?for (j = i + 1;j < n && R - L <= K;j++) {
            ?? ??? ?更新L,R
            ?? ?}
            ?? ?更新answer
            }

            但是n是10^5,n^2會(huì)超時(shí)。
            求區(qū)間最大值最小值可以用rmq,O(nlogn)預(yù)處理,O(1)的得到。
            一定存在一個(gè)j,使得a [i ... j]合法,a[j + 1 ..n]不合法。
            好的方法是二分搜索到這個(gè)j,水點(diǎn)的方法可以從后往前找j。

            RMQ 可以線段樹,也可以SparseTable
            總復(fù)雜度O(nlogn)
            codeforces 可以看代碼,想看的會(huì)去找吧。這里的二分搜有trick,求的是upper_bound不是一般寫的lower_bound,需要調(diào)整。

            posted on 2010-03-28 01:17 schindlerlee 閱讀(1554) 評(píng)論(3)  編輯 收藏 引用 所屬分類: 解題報(bào)告

            Feedback

            # re: 2010年03月28日星期日.codeforces beta6 2010-03-28 07:54 MasterLuo

            我覺得E二分是會(huì)有問題的?并不滿足單調(diào)性。
            我有個(gè)想法就是用二條掃描線,外加一個(gè)最小堆來維護(hù)。  回復(fù)  更多評(píng)論   

            # re: 2010年03月28日星期日.codeforces beta6 2010-03-28 10:08 schindlerlee

            @MasterLuo
            我覺得是單調(diào)的,肯定是前邊合法,后邊不合法了
            還有就是我相信sgu那幫人做的動(dòng)不動(dòng)上百組的測試數(shù)據(jù)...
            另外,我不太明白你說的掃描,我感覺那樣豈不是n^2了?


             1 for (i = 0;i < n;i++) {
             2     int L = i,R = n;
             3     while (L < R) {
             4         int mid = (L + R) / 2;
             5         int tmp = bigrmq(i,mid) - smlrmq(i,mid);
             6         if (tmp <= diff) {
             7             if (L == mid) { break;}
             8             L = mid;
             9         }else {
            10             if (R == mid + 1) {break;}
            11             R = mid + 1;
            12         }
            13     }
            14     int tmp = L - i + 1;
            15     if (tmp > ans) {
            16         ans = tmp;
            17         記錄結(jié)果
            18     }else if (tmp == ans) {
            19         記錄結(jié)果
            20     }
            21 }


              回復(fù)  更多評(píng)論   

            # re: 2010年03月28日星期日.codeforces beta6 2010-03-28 10:48 MasterLuo

            @schindlerlee
            掃描是NlogN的,因?yàn)槲覀儚牡谝粋€(gè)開始每加入一個(gè)數(shù)后如果引起了不滿足題意條件,那么一定是最新加入的那個(gè)數(shù)引起的,現(xiàn)在還在堆中的最大數(shù)與最小數(shù)之間一定會(huì)有一個(gè)要退出,可以證明它與后面要加入的數(shù)也不能滿足條件。于是我們找到位置在前面的那個(gè)數(shù),把它前面所有的數(shù)都刪除。再判斷,直到滿足條件為止。這樣每個(gè)數(shù)就只進(jìn)優(yōu)先隊(duì)列一次,也只出優(yōu)先隊(duì)列一次。 我寫了下代碼,驗(yàn)證了一下,過上去過了。
            C++語言: 臨時(shí)自用代碼


            int n, k, maxVal, minVal;
            int arr[100000], ans = 0, maxLen = 1, red[100000][2];
            struct Node {
            int loc, val;
            }node;
            struct CMP_1 {
            bool operator()(const Node& min, const Node& max) {
            if((min.val > max.val) ||(min.val == max.val && min.loc > max.loc))
            return true;
            return false;
            }
            };
            struct CMP_2 {
            bool operator()(const Node& min, const Node& max) {
            if((min.val < max.val) || (min.val == max.val && min.loc > max.loc))
            return true;
            return false;
            }
            };
            int last = 0;
            int main() {
            scanf("%d %d", &n, &k);
            for(int i = 0; i < n; ++i) {
            scanf("%d", &arr[i]);
            }
            priority_queue<Node, vector<Node>, CMP_1> pri;
            priority_queue<Node, vector<Node>, CMP_2> pri2;

            for(int i = 0; i < n; ++i) {
            node.val = arr[i];
            node.loc = i;
            pri.push(node);
            pri2.push(node);

            int minVal = pri.top().val;
            int maxVal = pri2.top().val;

            while(maxVal - minVal > k) {
            int lt = min(pri.top().loc, pri2.top().loc);
            while(!pri.empty() && pri.top().loc <= lt) {
            pri.pop();
            }
            while(!pri2.empty() && pri2.top().loc <= lt) {
            pri2.pop();
            }
            last = lt + 1;
            minVal = pri.top().val;
            maxVal = pri2.top().val;
            }
            int tmpLen = i - last + 1;
            if(tmpLen == maxLen) {
            red[ans][0] = last;
            red[ans][1] = i;
            ++ans;
            }
            if(tmpLen > maxLen) {
            red[0][0] = last;
            red[0][1] = i;
            ans = 1;
            maxLen = tmpLen;
            }
            }
            printf("%d %d\n", maxLen, ans);
            for(int i = 0; i < ans; ++i) {
            printf("%d %d\n", red[i][0] + 1, red[i][1] + 1);
            }
            return 0;
            }

              回復(fù)  更多評(píng)論   

            久久国产精品偷99| 久久笫一福利免费导航 | 青青青国产成人久久111网站| 久久成人小视频| 日韩久久无码免费毛片软件| 国产精品美女久久久久网| 伊人久久大香线蕉综合影院首页 | 久久夜色精品国产噜噜亚洲a| 久久国产成人精品麻豆| 99久久免费国产特黄| 久久香蕉超碰97国产精品| 久久亚洲精品成人av无码网站| 色婷婷久久综合中文久久蜜桃av| 亚洲国产精品无码久久久秋霞2| 久久亚洲AV成人无码电影| 精品久久8x国产免费观看| 久久99国产精品一区二区| 99久久国产综合精品五月天喷水 | 国产免费久久精品99re丫y| 精品国产乱码久久久久软件| 老男人久久青草av高清| 欧美一区二区三区久久综合 | 亚洲中文字幕无码久久2020| 午夜天堂av天堂久久久| 久久国产精品久久精品国产| 久久93精品国产91久久综合| 欧美亚洲国产精品久久高清| AV色综合久久天堂AV色综合在| 国产精品欧美久久久久无广告 | 国产精品9999久久久久| 99国内精品久久久久久久 | 久久精品亚洲AV久久久无码| 日日噜噜夜夜狠狠久久丁香五月| 久久精品国产99久久无毒不卡| 久久99精品国产99久久6| 久久人人爽人人爽人人片av麻烦 | 亚洲人成无码网站久久99热国产| 日本久久久久亚洲中字幕| 久久久WWW免费人成精品| 久久久久久国产精品免费无码| 国产成人精品久久亚洲|