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

            superman

            聚精會神搞建設 一心一意謀發展
            posts - 190, comments - 17, trackbacks - 0, articles - 0
               :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Section 1.2 - Milking Cows

            Posted on 2009-03-12 15:17 superman 閱讀(128) 評論(0)  編輯 收藏 引用 所屬分類: USACO
             1 #include <iostream>
             2 
             3 using namespace std;
             4 
             5 struct Interval
             6 {
             7     int s, t;
             8 
             9     bool operator < (const Interval & i) const
            10     {
            11         return s < i.s;
            12     }
            13 }   interval[5000];
            14 
            15 int main()
            16 {
            17     freopen("milk2.in""r", stdin);
            18     freopen("milk2.out""w", stdout);
            19 
            20     int n;
            21 
            22     cin >> n;
            23     for (int i = 0; i < n; i++)
            24         cin >> interval[i].s >> interval[i].t;
            25 
            26     sort(interval, interval + n);
            27 
            28     int p = 0;
            29 
            30     bool toBeDeleted[5000= { false };
            31     for (int i = 0; i < n - 1; i++)
            32         for (int j = i + 1; interval[i].t > interval[j].t && j < n; j++)
            33             toBeDeleted[j] = true;
            34     for (int i = 0; i < n; i++)
            35         if (toBeDeleted[i] == false)
            36         {
            37             interval[p].s = interval[i].s;
            38             interval[p].t = interval[i].t;
            39             p++;
            40         }
            41 
            42     n = p;
            43 
            44     bool toBeUnited[5000= { false };
            45     for (int i = 1; i < n; i++)
            46         if (interval[i].s <= interval[i - 1].t)
            47             toBeUnited[i] = true;
            48 
            49     p = 0;
            50     for (int i = 0; i < n; )
            51     {
            52         int j = i;
            53         while (toBeUnited[j + 1== true)
            54             j++;
            55         if (i == j)
            56         {
            57             interval[p].s = interval[i].s;
            58             interval[p].t = interval[i].t;
            59             p++;
            60         }
            61         else
            62         {
            63             interval[p].s = interval[i].s;
            64             interval[p].t = interval[j].t;
            65             p++;
            66         }
            67         i = j + 1;
            68     }
            69 
            70     int longestContinuousTime = 0, longestIdleTime = 0;
            71     for (int i = 0; i < p; i++)
            72         longestContinuousTime >?= interval[i].t - interval[i].s;
            73     for (int i = 0; i < p - 1; i++)
            74         longestIdleTime >?= interval[i + 1].s - interval[i].t;
            75 
            76     cout << longestContinuousTime << ' ' << longestIdleTime << endl;
            77 
            78     return 0;
            79 }
            80 
            久久久精品波多野结衣| 久久国产亚洲精品麻豆| 国产精品狼人久久久久影院| 亚洲综合熟女久久久30p| 日韩AV毛片精品久久久| 久久精品国产福利国产琪琪| 狠狠精品久久久无码中文字幕| 久久精品黄AA片一区二区三区| 国产偷久久久精品专区| 亚洲AV无码久久精品成人| 亚洲国产另类久久久精品| 国产色综合久久无码有码| 欧美喷潮久久久XXXXx| 久久国产精品无码一区二区三区| 久久大香香蕉国产| 精品午夜久久福利大片| 久久精品国产99国产精品| 伊人久久国产免费观看视频| 精品人妻伦九区久久AAA片69| 无码国内精品久久人妻蜜桃| 久久精品国产亚洲AV无码偷窥| 国产精品久久午夜夜伦鲁鲁| 久久亚洲国产精品一区二区| 久久WWW免费人成—看片| 久久只有这里有精品4| 无码国内精品久久人妻蜜桃| 成人免费网站久久久| 久久免费99精品国产自在现线 | 久久久国产精品福利免费| 狠狠色伊人久久精品综合网| 久久国产精品无| 东京热TOKYO综合久久精品| 久久996热精品xxxx| 亚洲国产另类久久久精品小说| 狠狠色丁香久久综合五月| 亚洲欧美久久久久9999| 激情伊人五月天久久综合| 久久久久亚洲AV成人网| 97久久国产亚洲精品超碰热 | 久久WWW免费人成一看片| 国产精品成人精品久久久|