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

posts - 101,  comments - 57,  trackbacks - 0
線段樹經(jīng)典解決問題poj1151,計(jì)算圖形覆蓋總面積。

1.用了半小時(shí)寫了一個(gè)簡(jiǎn)單算法,看了看測(cè)試數(shù)據(jù)沒過,原來理解題意錯(cuò)誤。(如果提交就是WA)
2.然后又用了樸素的枚舉,這次是TLE,看來是水平不行,要學(xué)習(xí)學(xué)習(xí)別人的思路了。
3.看完別人代碼后,花了半天用自己的思路寫了一遍,RTE。
4.原來是數(shù)組設(shè)小了,再次提交PE。
4.最后居然是要輸出兩個(gè)換行,暈倒!AC

線段樹的應(yīng)用還有很多,就此題來說基本的思維是用線段樹的方法就每一塊面積單獨(dú)進(jìn)行計(jì)算(按x軸分塊),然后累加。此題由于是浮點(diǎn)型,還用到了離散化的方法來幫助線段樹來進(jìn)行轉(zhuǎn)化。

最后show一下代碼
  1#include "stdio.h"
  2#include "stdlib.h"
  3
  4#define MAX 100
  5
  6struct node
  7{
  8    int left;
  9    int right;
 10    double h;
 11    double y2;
 12}
xdtree[5 * MAX + 11];
 13
 14// xdtree_leaf_size = 2^(n - 1) = 200 < 256
 15//                n < 9
 16// xdtree_size = 2^n - 1 =  511;
 17struct axis
 18{
 19    double x1;
 20    double y1;
 21    double x2;
 22    double y2;
 23}
area[MAX];
 24
 25double d[2 * MAX];
 26
 27void build_tree(int n, int l, int r)
 28{
 29    int m;
 30
 31    xdtree[n].left  = l;
 32    xdtree[n].right = r;
 33    xdtree[n].h     = 0;
 34    xdtree[n].y2    = 0;
 35    
 36    if (r - l == 1)
 37        return;
 38
 39    m = (r + l) >> 1;
 40
 41    build_tree(2 * n + 1, l, m);
 42    build_tree(2 * n + 2, m, r);
 43}

 44
 45void insert(int i, double x1, double y1, double x2, double y2)
 46{
 47    int m;
 48
 49    if (xdtree[i].y2 >= y2)
 50        return;
 51    
 52    if (xdtree[i].right - xdtree[i].left == 1)
 53    {    
 54        
 55        if (d[xdtree[i].left] == x1 && d[xdtree[i].right] == x2)
 56        {
 57            if (xdtree[i].y2 > y1)
 58            {
 59                xdtree[i].h += y2 - xdtree[i].y2;
 60            }

 61            else
 62            {
 63                xdtree[i].h += y2 - y1;
 64            }

 65            xdtree[i].y2 = y2;
 66        }

 67    }

 68    else
 69    {
 70        m = (xdtree[i].left + xdtree[i].right) >> 1;
 71        
 72        if (d[m] >= x2)
 73        {
 74            insert(2 * i + 1, x1, y1, x2, y2);
 75        }

 76        else if (d[m] <= x1)
 77        {
 78            insert(2 * i + 2, x1, y1, x2, y2);
 79        }

 80        else
 81        {
 82            insert(2 * i + 1, x1, y1, d[m], y2);
 83            insert(2 * i + 2, d[m], y1, x2, y2);
 84        }

 85    }

 86}

 87
 88double calc(int i)
 89{
 90    if (xdtree[i].right - xdtree[i].left == 1)
 91    {
 92        return xdtree[i].h * (d[xdtree[i].right] - d[xdtree[i].left]);
 93    }

 94    else
 95    {
 96        return calc(2 * i + 1+ calc(2 * i + 2);
 97    }

 98}

 99
100
101int cmp_d(const double *p1, const double *p2)
102{
103    if (*p1 > *p2)
104        return 1;
105    else if (*p1 == *p2)
106        return 0;
107    else
108        return -1;
109}

110
111int cmp_y1(const struct axis *p1, const struct axis *p2)
112{
113    return cmp_d(&p1->y1, &p2->y1);
114}

115
116void main()
117{
118    int c, i, j, k, n;
119    
120    n = 0;
121    
122    while (scanf("%d"&c))
123    {
124        if (!c) break;
125        
126        for (i = 0, k = 0; i < c; ++i)
127        {
128            scanf("%lf %lf %lf %lf"&area[i].x1, &area[i].y1, &area[i].x2, &area[i].y2);
129            d[k++= area[i].x1;
130            d[k++= area[i].x2;
131        }

132
133        qsort(d, k, sizeof(d[0]), cmp_d);
134        
135        for (i = 1, j = 0; i < k; ++i)
136        {
137            if (d[j] != d[i])
138            {
139                d[++j] = d[i];
140            }

141        }

142
143        build_tree(00, j);
144
145        qsort(area, c, sizeof(area[0]), cmp_y1);
146
147        for (i = 0; i < c; i++)
148        {
149            insert(0, area[i].x1, area[i].y1, area[i].x2, area[i].y2);
150        }

151        printf("Test case #%d\nTotal explored area: %0.2lf\n\n"++n, calc(0));
152    }

153}

154
posted on 2010-08-15 23:38 margin 閱讀(271) 評(píng)論(0)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用鏈接

留言簿

隨筆檔案

文章分類

文章檔案

收藏夾

常去的壇子

  • CVC電腦病毒論壇
  • 很多人說我是AV,我告訴他們:別瞧不起人,我們也能創(chuàng)造價(jià)值
  • 安全焦點(diǎn)
  • 黑客聚集的地方,一般是好酒最多的地方...
  • 看雪論壇
  • 國內(nèi)最強(qiáng)的加密解密論壇,成醉其中經(jīng)常夜不歸宿
  • 驅(qū)動(dòng)開發(fā)論壇
  • 厭倦了啤的朋友們,來我們來整點(diǎn)白的...痛痛快快的BSOD也好過隔鞋瘙癢!

我的朋友

  • Sen的blog
  • IDE方面資深的受害者...經(jīng)常為一個(gè)變量的定義找不著北的痛苦程序員(深表同情)
  • 老羅的blog
  • 良師益友,千年水牛,引擎猛男,分析怪獸,墨鏡酷哥,臺(tái)球高手....

搜索

  •  

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            一片黄亚洲嫩模| 国产亚洲视频在线| 久久久精彩视频| 一卡二卡3卡四卡高清精品视频| 久久综合色8888| 欧美尤物一区| 亚洲曰本av电影| 一本久久综合| 亚洲人成亚洲人成在线观看图片| 国产在线播精品第三| 国产精品国色综合久久| 欧美屁股在线| 欧美激情中文字幕在线| 久久视频这里只有精品| 久久成人精品无人区| 欧美一区二区成人6969| 中文精品99久久国产香蕉| 一本大道av伊人久久综合| 亚洲精品久久久久| 亚洲福利视频网站| 亚洲第一页中文字幕| 免费日韩精品中文字幕视频在线| 久久免费高清视频| 久久久久一本一区二区青青蜜月| 香蕉久久a毛片| 欧美亚洲一区二区在线观看| 香蕉久久久久久久av网站| 亚洲免费在线精品一区| 亚洲女同性videos| 午夜精品亚洲| 欧美中文字幕在线视频| 欧美专区日韩专区| 久久久精品国产免大香伊| 久久久国产91| 美女久久一区| 亚洲高清久久网| 亚洲精品视频免费观看| 一本色道**综合亚洲精品蜜桃冫 | 亚洲精品小视频在线观看| 亚洲国产乱码最新视频| 亚洲精品在线电影| 一区二区欧美视频| 亚洲欧美日本另类| 久久成年人视频| 久久久久久久97| 女主播福利一区| 亚洲国产精品高清久久久| 亚洲国产激情| 一本色道久久综合亚洲91| 亚洲午夜精品福利| 久久成人免费| 欧美电影免费观看高清完整版| 欧美欧美天天天天操| 国产精品区一区二区三区| 国产综合精品一区| 亚洲国产婷婷香蕉久久久久久| 亚洲理论在线| 性久久久久久久久| 美女精品网站| 亚洲免费成人| 欧美在线一二三区| 欧美电影资源| 国产精品久久久久7777婷婷| 国内精品国产成人| 亚洲精品韩国| 欧美一区二区三区精品电影| 免费人成精品欧美精品| 一本一本a久久| 久久久久久久成人| 欧美视频一区二区三区…| 黄色精品一区二区| 亚洲午夜久久久久久久久电影网| 久久久久久久久岛国免费| 最新日韩中文字幕| 性欧美在线看片a免费观看| 美女脱光内衣内裤视频久久影院 | 欧美日韩国产影片| 国产在线日韩| 亚洲视频欧美视频| 久久综合中文| 一本色道久久综合| 麻豆成人在线| 国产日韩欧美在线一区| 99pao成人国产永久免费视频| 久久精品免费观看| 一本久道久久久| 老牛国产精品一区的观看方式| 国产精品美女久久久久久免费| 亚洲福利视频在线| 久久电影一区| 亚洲视频第一页| 欧美麻豆久久久久久中文| 狠狠色狠狠色综合日日91app| 在线亚洲欧美| 亚洲激情网站免费观看| 久久免费少妇高潮久久精品99| 国产精品乱码一区二区三区| 亚洲精品乱码久久久久| 久久视频一区| 亚洲欧美另类综合偷拍| 欧美另类人妖| 亚洲国产专区校园欧美| 久久综合国产精品台湾中文娱乐网| 亚洲在线电影| 国产精品久久久久久久久果冻传媒 | 亚洲综合色自拍一区| 亚洲国产精品一区二区www| 久久成人免费日本黄色| 国产欧美日韩一区二区三区在线观看| 一本色道久久88亚洲综合88| 欧美激情国产精品| 巨乳诱惑日韩免费av| 精品福利电影| 久久综合狠狠综合久久激情| 久久国产精品色婷婷| 国产亚洲精品美女| 久久成人在线| 欧美一区永久视频免费观看| 国产精品一区二区久久精品| 亚洲图片在线| 一本色道久久综合狠狠躁篇的优点| 欧美伦理91i| 一区二区国产在线观看| 亚洲六月丁香色婷婷综合久久| 欧美精品一区二区蜜臀亚洲| 日韩午夜三级在线| 亚洲日本免费电影| 欧美人与性禽动交情品 | 久久深夜福利免费观看| 欧美亚洲综合另类| 激情成人综合| 欧美国产一区二区在线观看| 欧美福利小视频| 一本色道久久综合亚洲精品婷婷| 亚洲精品裸体| 欧美四级在线观看| 篠田优中文在线播放第一区| 欧美一级久久久久久久大片| 国产专区欧美精品| 欧美91福利在线观看| 欧美国产日韩在线| 亚洲一区二区在线视频 | 欧美日产在线观看| 亚洲性色视频| 午夜精品三级视频福利| 一区在线免费观看| 亚洲国产精品综合| 欧美日韩一区二区国产| 性欧美办公室18xxxxhd| 久久av一区二区三区| 亚洲国产精品www| 亚洲欧洲久久| 国产精品久久久久久五月尺| 久久久91精品国产一区二区三区| 久久中文字幕一区| 亚洲香蕉网站| 性色av一区二区三区红粉影视| 亚洲高清电影| 亚洲网站在线| 国内精品一区二区三区| 亚洲国产99| 国产日本欧美在线观看| 欧美福利视频网站| 国产精品乱码妇女bbbb| 欧美大尺度在线| 国产精品国产三级国产专播品爱网 | 久久精品道一区二区三区| 麻豆精品精华液| 亚洲欧美日韩一区二区三区在线| 久久久国产亚洲精品| 中日韩高清电影网| 久久精品观看| 亚洲免费在线视频一区 二区| 久久久久久九九九九| 亚洲一区二区在线| 久久综合狠狠综合久久激情| 亚洲欧美自拍偷拍| 欧美99在线视频观看| 欧美一区二区三区视频| 欧美精品一区二区久久婷婷| 久久精品免费看| 欧美三级在线视频| 欧美成人精品h版在线观看| 欧美调教视频| 亚洲电影免费在线| 国产伊人精品| 亚洲视频视频在线| 亚洲伦理在线观看| 久久久久久久一区二区三区| 亚洲一区二区三区四区在线观看| 久久网站免费| 久久精精品视频| 国产精品乱人伦一区二区| 亚洲韩日在线| 亚洲成色777777在线观看影院| 亚洲一区视频在线| 亚洲午夜成aⅴ人片| 欧美成人精品h版在线观看| 久久亚洲综合色| 国产模特精品视频久久久久 |