• <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 閱讀(421) 評論(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 
            激情伊人五月天久久综合| 国内精品久久久久影院薰衣草| 久久久久国产精品人妻| 国色天香久久久久久久小说| 亚洲AV日韩AV永久无码久久| 9久久9久久精品| 欧美成人免费观看久久| 国产精品久久国产精品99盘| 国产真实乱对白精彩久久| 日韩人妻无码精品久久免费一| 欧美精品一本久久男人的天堂| 久久天天躁狠狠躁夜夜2020一 | 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 国产精品久久新婚兰兰| 97久久超碰国产精品旧版| 亚洲国产精品一区二区三区久久| 国产精品女同久久久久电影院| 天天影视色香欲综合久久| 久久er热视频在这里精品| 久久人人爽人人爽人人片AV东京热| 一本伊大人香蕉久久网手机| 狠狠综合久久综合88亚洲| 国产午夜精品理论片久久| 久久被窝电影亚洲爽爽爽| 一本一本久久a久久综合精品蜜桃| 精品久久久久中文字幕一区| 久久精品国产亚洲AV电影 | 久久精品国产2020| 久久福利资源国产精品999| 久久av高潮av无码av喷吹| 99久久99久久精品国产片果冻| 久久精品夜夜夜夜夜久久| 亚洲精品乱码久久久久66| 色天使久久综合网天天| 精品国产乱码久久久久软件| 久久人人爽人人爽AV片| 国产2021久久精品| 久久久无码精品亚洲日韩软件| 精品久久久久国产免费| 精品无码久久久久久久久久| 久久99精品免费一区二区|