• <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
               :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            ZOJ 1197 - Sorting Slides

            Posted on 2008-04-09 19:52 superman 閱讀(422) 評論(0)  編輯 收藏 引用 所屬分類: ZOJ
              1 /* Accepted 1197 C++ 00:00.00 836K */
              2 #include <iostream>
              3 
              4 using namespace std;
              5 
              6 struct { int x1, y1, x2, y2, match; } slide[26];
              7 struct { int x, y; bool matched; } p[26];
              8 
              9 int n;
             10 
             11 bool s1()
             12 {
             13     for(int i = 0; i < n; i++)
             14         if(slide[i].match == -1)
             15         {
             16             int cnt = 0, idx;
             17             for(int j = 0; j < n; j++)
             18                 if(p[j].matched == false)
             19                     if(slide[i].x1 <= p[j].x && p[j].x <= slide[i].x2)
             20                     if(slide[i].y1 <= p[j].y && p[j].y <= slide[i].y2)
             21                     {
             22                         cnt++;
             23                         idx = j;
             24                         if(cnt > 1)
             25                             break;
             26                     }
             27             if(cnt == 1)
             28             {
             29                 slide[i].match = idx;
             30                 p[idx].matched = true;
             31                 return true;
             32             }
             33         }
             34     return false;
             35 }
             36 
             37 bool s2()
             38 {
             39     for(int i = 0; i < n; i++)
             40         if(p[i].matched == false)
             41         {
             42             int cnt = 0, idx;
             43             for(int j = 0; j < n; j++)
             44                 if(slide[j].match == -1)
             45                     if(slide[j].x1 <= p[i].x && p[i].x <= slide[j].x2)
             46                     if(slide[j].y1 <= p[i].y && p[i].y <= slide[j].y2)
             47                     {
             48                         cnt++;
             49                         idx = j;
             50                         if(cnt > 1)
             51                             break;
             52                     }
             53             if(cnt == 1)
             54             {
             55                 p[i].matched = true;
             56                 slide[idx].match = i;
             57                 return true;
             58             }
             59         }
             60     return false;
             61 }
             62 
             63 int main()
             64 {
             65     int Heap = 0;
             66     while((cin >> n) && n)
             67     {
             68         for(int i = 0; i < n; i++)
             69         {
             70             slide[i].match = -1;
             71             cin >> slide[i].x1 >> slide[i].x2 >> slide[i].y1 >> slide[i].y2;
             72         }
             73         for(int i = 0; i < n; i++)
             74         {
             75             p[i].matched = false;
             76             cin >> p[i].x >> p[i].y;
             77         }
             78         
             79         int m = 0;
             80         while(s1())m++;
             81         while(s2())m++;
             82         
             83         cout << "Heap " << ++Heap << endl;
             84         
             85         if(m == 0)
             86             cout << "none" << endl;
             87         else
             88         {
             89             while(m)
             90                 for(int i = 0; i < n; i++)
             91                     if(slide[i].match != -1)
             92                     {
             93                         cout << '(' << char(i + 'A'<< ',' << slide[i].match + 1 << ')';
             94                         cout << (--== 0 ? '\n' : ' ');
             95                     }
             96         }
             97         cout << endl;
             98     }
             99     
            100     return 0;
            101 }
            102 
            国产人久久人人人人爽 | 精品人妻久久久久久888| 久久精品国产2020| 国产产无码乱码精品久久鸭| 国产成人综合久久精品尤物| 伊人精品久久久久7777| 国产精品免费看久久久| 久久精品无码一区二区三区日韩| 久久人人爽人人爽人人片AV高清 | 91久久成人免费| 性做久久久久久久久| 久久91精品国产91久久小草| 国产福利电影一区二区三区久久久久成人精品综合 | 无码日韩人妻精品久久蜜桃| 国产成人99久久亚洲综合精品 | 久久综合成人网| 国产精品禁18久久久夂久| 中文成人久久久久影院免费观看 | 久久丫精品国产亚洲av不卡 | 久久精品aⅴ无码中文字字幕不卡| 99麻豆久久久国产精品免费 | 一本大道久久香蕉成人网| 久久久久久久综合日本亚洲 | 久久久久久精品免费看SSS| 国产免费福利体检区久久| 日韩人妻无码精品久久免费一| 美女久久久久久| 久久播电影网| 久久996热精品xxxx| 草草久久久无码国产专区| 久久精品国产99国产电影网| 久久久久久久久久久久中文字幕| 久久久久亚洲AV无码观看| 久久久久亚洲AV成人网| 国产亚洲精久久久久久无码AV| 久久精品无码午夜福利理论片| 一本色道久久HEZYO无码| 精品伊人久久大线蕉色首页| 波多野结衣AV无码久久一区| 精品综合久久久久久97| 麻豆AV一区二区三区久久|