• <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 閱讀(423) 評論(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 
            久久99精品国产麻豆宅宅| 性做久久久久久久久久久| 伊人久久无码中文字幕| 国产成人久久精品激情| 久久精品综合一区二区三区| 亚洲色大成网站www久久九| 精品久久久久久中文字幕| 久久夜色撩人精品国产小说| 色综合久久久久久久久五月| 久久精品国产精品亚洲人人 | 久久伊人五月丁香狠狠色| 精品国产VA久久久久久久冰| 久久99国产精品久久99| 色青青草原桃花久久综合| 久久99精品国产| 久久综合综合久久综合| 久久99精品久久久久久秒播| 2022年国产精品久久久久| 怡红院日本一道日本久久| 精品久久国产一区二区三区香蕉| 一本一本久久A久久综合精品| 久久久久亚洲AV无码专区桃色| 91久久精一区二区三区大全| 久久热这里只有精品在线观看| 久久国产三级无码一区二区| 久久久无码精品亚洲日韩蜜臀浪潮| 久久夜色撩人精品国产| 国产91久久综合| 99久久精品无码一区二区毛片| 久久精品国产半推半就| 99麻豆久久久国产精品免费| 亚洲色大成网站www久久九| 久久伊人精品一区二区三区| 亚洲色欲久久久久综合网| 久久婷婷色综合一区二区| 久久精品国产清自在天天线| 99热热久久这里只有精品68| 婷婷综合久久中文字幕| 亚洲国产成人久久综合一| 久久精品男人影院| 欧美日韩成人精品久久久免费看|