青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

USACO chapter 3 section 1 Shaping Regions

USER: tian tianbing [tbbd4261]
TASK: rect1
LANG: C++

Compiling...
Compile: OK

Executing...
   Test 1: TEST OK [0.000 secs, 3024 KB]
   Test 2: TEST OK [0.000 secs, 3024 KB]
   Test 3: TEST OK [0.011 secs, 3024 KB]
   Test 4: TEST OK [0.000 secs, 3024 KB]
   Test 5: TEST OK [0.000 secs, 3024 KB]
   Test 6: TEST OK [0.000 secs, 3024 KB]
   Test 7: TEST OK [0.022 secs, 3024 KB]
   Test 8: TEST OK [0.011 secs, 3024 KB]
   Test 9: TEST OK [0.022 secs, 3024 KB]
   Test 10: TEST OK [0.022 secs, 3024 KB]
   Test 11: TEST OK [0.022 secs, 3024 KB]

All tests OK.
Your program ('rect1') produced all correct answers!  This is your
submission #15 for this problem.  Congratulations!
 
     終于做出來了,用隊列實現,沒接收一個就遍歷整個隊列。要注意的是要把隊列的大小用t記下,因為
新加進來的會改變隊列的大小。
    用的是矩形分割:
原來的程序在分割與a相交的矩形b的時候,把a與b相交的部分也作為一個小矩形放在了后面。
這也就會多出很多,統計了一下對于最后一組測試數據有40多萬個矩形,超時。
其實應該把a整個放進去,不該把a也分割的。



 

/*
ID:tbbd4261
PROG:rect1
LANG:C++
*/

#include
<fstream>
#include
<queue>
#include
<string.h>
using namespace std;
ifstream fin(
"rect1.in");
ofstream fout(
"rect1.out");
struct type
{
       
int x1,y1,x2,y2,color;
};

int w,h,n,i,cnt;
int color[2505]={0};
queue
<type>Q;
inline 
int max(int a, int b){ return a>b?a:b; }
inline 
int min(int a, int b){ return a>b?b:a; } 
bool isIn(type &a, type &b)//判斷是否相交 
{
    
if(a.x1>=b.x2)return false;
    
if(a.x2<=b.x1)return false;
    
if(a.y1>=b.y2)return false;
    
if(a.y2<=b.y1)return false;
    
return true;
}

void add(int x1, int y1, int x2, int y2, int c)
{
      type t; t.x1
=x1; t.y1=y1; t.x2=x2; t.y2=y2; t.color=c; 
      color[c]
+=(x2-x1)*(y2-y1);
      Q.push(t);
}

 
void dec()
{
       type t
=Q.front(); Q.pop();
       color[t.color]
-=(t.x2-t.x1)*(t.y2-t.y1);
}

 
void deal(type &a, type &b) //a與b交,b的下標是j                 
 {     
     
if(a.x1>b.x1&&a.x1<b.x2) add(b.x1, b.y1,a.x1,b.y2,b.color);//S1
     if(a.x2>b.x1&&a.x2<b.x2) add(a.x2,b.y1, b.x2, b.y2,b.color); //S3
     if(a.y1>b.y1&&a.y1<b.y2) add(max(a.x1,b.x1),b.y1,min(a.x2,b.x2),a.y1,b.color);//S2
     if(a.y2>b.y1&&a.y2<b.y2) add(max(a.x1,b.x1),a.y2,min(a.x2,b.x2),b.y2,b.color);//S4
     
//add(max(a.x1,b.x1),max(a.y1,b.y1),min(a.x2,b.x2),min(a.y2,b.y2),a.color);//a與b相交的部分 
     dec();
 }

int main()
{
    memset(color,
0,sizeof color);
    fin
>>w>>h>>n;
    color[
1]=w*h;
    type temp;  
    temp.x1
=0; temp.y1=0; temp.x2=w; temp.y2=h; temp.color=1;
    Q.push(temp);
    
for(i=1; i<=n; i++)
    {
             fin
>>temp.x1>>temp.y1>>temp.x2>>temp.y2>>temp.color;
             
for(int t=Q.size(),j=1;j<=t; j++ )
                     
if(isIn(temp,Q.front() ))
                          deal( temp,Q.front() );
                     
else { type t=Q.front(); Q.pop();Q.push(t); }//如果不相交,放在隊列后面
        add(temp.x1,temp.y1,temp.x2,temp.y2,temp.color);
    }
    
for(i=1; i<=2500; i++)
              
if(color[i]) fout<<i<<' '<<color[i]<<endl;  
              
    
return 0;
}

 

posted on 2010-08-04 16:51 田兵 閱讀(132) 評論(0)  編輯 收藏 引用 所屬分類: USACO

<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

導航

統計

常用鏈接

留言簿(2)

隨筆分類(65)

隨筆檔案(65)

文章檔案(2)

ACM

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产主播精品| 久久成人国产精品| 免费亚洲婷婷| 欧美一区二区三区四区夜夜大片| 欧美看片网站| 在线观看视频一区| 久久久一区二区三区| 午夜精品一区二区三区电影天堂| 国产精品av久久久久久麻豆网| 日韩视频一区二区三区在线播放| 欧美成人a视频| 久久综合网色—综合色88| 伊人成人开心激情综合网| 午夜视频一区在线观看| 亚洲少妇自拍| 国产精品色午夜在线观看| 香蕉久久夜色精品国产| 亚洲午夜成aⅴ人片| 国产精品久久久久久久午夜| 亚洲一区二区日本| 亚洲精品偷拍| 国产精品久久一卡二卡| 性高湖久久久久久久久| 欧美一区二区三区在| 国产曰批免费观看久久久| 午夜精品视频在线| 欧美综合激情网| 亚洲高清资源| 亚洲日本免费电影| 国产精品久久久久久久午夜| 亚洲欧美日韩精品| 欧美专区亚洲专区| 亚洲精品激情| 欧美一区二区在线免费播放| 亚洲精品一区二区网址| 欧美一级久久久| 亚洲视频自拍偷拍| 可以看av的网站久久看| 欧美一区二区三区的| 欧美激情精品久久久久久免费印度| 亚洲欧美色一区| 欧美激情成人在线视频| 久久网站热最新地址| 国产精品久久亚洲7777| 亚洲激情不卡| 在线观看日韩欧美| 欧美一进一出视频| 亚洲欧美日韩在线观看a三区| 欧美www视频| 免费视频一区| 精品福利免费观看| 欧美伊人久久久久久午夜久久久久| 亚洲视频电影图片偷拍一区| 久久综合一区| 美女图片一区二区| 国内精品亚洲| 欧美一区二区三区免费视| 欧美亚洲视频在线看网址| 欧美日韩免费观看一区=区三区| 欧美va天堂| 在线视频国内自拍亚洲视频| 欧美一区二区三区免费看| 欧美在线日韩在线| 国产精品欧美精品| 亚洲与欧洲av电影| 性欧美暴力猛交另类hd| 国产精品久久久久久久久久免费| 亚洲精品一二三| 一区电影在线观看| 欧美激情a∨在线视频播放| 欧美激情一区二区三区四区 | 亚洲欧美日韩天堂| 亚洲午夜精品久久久久久浪潮| 欧美另类一区| 99视频一区| 午夜影院日韩| 国产日韩在线一区| 久久精品国产亚洲a| 欧美1区2区| 亚洲精品欧美专区| 欧美午夜激情视频| 亚洲欧美日本另类| 美女视频黄a大片欧美| 亚洲国产第一| 欧美久久久久久久久| 亚洲精品网址在线观看| 亚洲女人天堂av| 国产一区二区三区黄视频| 久久久久国产精品一区| 欧美国产精品日韩| 亚洲网友自拍| 国产揄拍国内精品对白| 蜜桃av一区二区| 日韩一区二区电影网| 欧美在线视频一区二区| 亚洲国产精彩中文乱码av在线播放| 欧美α欧美αv大片| 中日韩高清电影网| 久久久久久综合| 亚洲剧情一区二区| 国产精品一区二区女厕厕| 久久亚洲春色中文字幕久久久| 亚洲国产导航| 久久精品91久久久久久再现| 亚洲承认在线| 国产精品久久久免费| 狂野欧美性猛交xxxx巴西| 一区二区三区精密机械公司 | 欧美高清一区二区| 亚洲五月婷婷| 亚洲第一视频| 国产精品另类一区| 欧美电影电视剧在线观看| 亚洲欧美乱综合| 亚洲区中文字幕| 老司机精品视频网站| 亚洲永久免费av| 亚洲日本成人网| 国内自拍一区| 国产精品一区二区你懂的| 欧美激情精品久久久久久黑人 | 欧美高清在线视频| 性8sex亚洲区入口| 一本色道久久88亚洲综合88| 含羞草久久爱69一区| 欧美日韩免费观看一区=区三区| 久久麻豆一区二区| 午夜精品久久久久久久蜜桃app | 日韩亚洲欧美中文三级| 久久五月天婷婷| 欧美制服丝袜| 欧美影院一区| 亚洲欧美中文另类| 亚洲一区二区三区在线| 亚洲美女免费视频| 亚洲精品一区二区三区在线观看| 国产综合色精品一区二区三区| 国产精品视频免费观看| 欧美午夜精品久久久久久浪潮| 欧美黄色精品| 欧美激情第三页| 欧美成人影音| 欧美激情中文不卡| 欧美高清视频在线 | 中文在线不卡视频| 99视频精品在线| 亚洲美女啪啪| 在线视频精品一区| 亚洲视频网在线直播| 在线亚洲欧美视频| 亚洲一区免费网站| 亚洲欧美一区二区三区在线| 亚洲欧美成人网| 香蕉久久夜色精品国产| 欧美在线短视频| 久久久人人人| 欧美激情一区二区久久久| 欧美激情一区二区三区全黄| 欧美精品一区在线播放| 欧美日韩国产一区二区| 国产精品美女xx| 国产一区二区三区高清| 亚洲成人资源| 在线视频免费在线观看一区二区| 亚洲视频综合在线| 久久电影一区| 欧美成人一区二区三区| 亚洲七七久久综合桃花剧情介绍| 亚洲美女精品成人在线视频| 亚洲在线视频| 久久手机精品视频| 欧美区在线观看| 国产精品影音先锋| 亚洲国产精品综合| 亚洲婷婷综合色高清在线| 久久成人免费网| 欧美激情亚洲激情| 亚洲伊人第一页| 久久久人成影片一区二区三区| 欧美激情亚洲国产| 国产亚洲精品久久久| 亚洲精品国精品久久99热| 亚洲欧美精品在线| 蜜臀久久99精品久久久画质超高清 | 亚洲视频 欧洲视频| 久久精品国产欧美激情| 亚洲高清成人| 亚洲欧美在线一区| 欧美激情a∨在线视频播放| 国产欧美日韩精品a在线观看| 亚洲欧洲精品一区二区三区不卡| 亚洲制服av| 亚洲国产精品www| 欧美一区二区三区久久精品茉莉花| 六月丁香综合| 国产一区激情| 午夜精品区一区二区三| 亚洲国产精品精华液网站| 欧美一区二区在线免费观看| 欧美日韩亚洲天堂|