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

數據加載中……

URAL 1019 A line painting

A Line painting

Time Limit: 2.0 second
Memory Limit: 16 MB
The segment of numerical axis from 0 to 109 is painted into white color. After that some parts of this segment are painted into black, then some into white again and so on. In total there have been made N re-paintings (1 ≤ N ≤ 5000). You are to write a program that finds the longest white open interval after this sequence of re-paintings.

Input

The first line of input contains the only number N. Next N lines contain information about re-paintings. Each of these lines has a form:
ai bi ci
where ai and bi are integers, ci is symbol 'b' or 'w', ai, bi, ci are separated by spaces.
This triple of parameters represents repainting of segment from ai to bi into color ci ('w' — white, 'b' — black). You may assume that 0 < ai < bi < 109.

Output

Output should contain two numbers x and y (x < y) divided by space(s). These numbers should define the longest white open interval. If there are more than one such an interval output should contain the one with the smallest x.

Sample

input output
4
1 999999997 b
40 300 w
300 634 w
43 47 b
47 634                                                        
這個題目最直接的辦法是離散化,離散化了之后就好折騰了,因為操作指令很少,所以我選擇離散+樸素染色.
復雜度上界為O(M*M),這里M表示離散化后得到的區間個數.

 1 #include<iostream>
 2 #include<algorithm>
 3 using namespace std;
 4 const int MAXN=10005;
 5 const int MAXL=1000000000;
 6 struct re
 7 {
 8   int a,b;
 9   char c;
10 }op[MAXN];
11 
12 int n,p=0,que[MAXN];
13 bool color[MAXN<<1];
14 
15 /* 二分查找 */
16 int find(int num)
17 {
18   int l=0,r=p+1,mid;
19   while (r-l>1)
20     {
21       mid=(l+r) >> 1;
22       (que[mid]<=num)? l=mid : r=mid;
23       if (que[l]==num) return l;
24     }
25   return l;
26 }
27 
28 void disp(re& op)
29 {
30   /* 區間由1開始數,而不是由0開始 */
31   op.a=find(op.a)+1;
32   op.b=find(op.b);
33 }
34 
35 void mark(int l,int r,char c)
36 {
37   for (int i=l;i<=r;++i) color[i]=(c=='b');
38 }
39 
40 int main()
41 {
42  // freopen("data.in","r",stdin);
43  // freopen("data.out","w",stdout);
44   cin >> n;
45   for (int i=0;i<n;++i)
46     {
47       cin >> op[i].a >> op[i].b >> op[i].c;
48       que[++p]=op[i].a;
49       que[++p]=op[i].b;
50     }
51   que[++p]=MAXL;
52   /* 刪除重復出現的數字 */
53   int rp=0;
54   for (int i=1;i<=p;++i)
55     if (que[rp]!=que[i]) que[++rp]=que[i];
56   p=rp;
57   /* 排序,便于定位和離散化 */
58   sort(que,que+p+1);
59   que[p+1]=MAXL+1;
60   /* 對操作進行離散處理 */
61   for (int i=0;i<n;++i) disp(op[i]);
62   /* 處理操作序列 */
63   memset(color,0,sizeof(color));
64   for (int i=0;i<n;++i) mark(op[i].a,op[i].b,op[i].c);
65   int t=1,a,b,mlen=0;
66   for (int i=2;i<=p+1;++i)
67     if (color[i]!=color[t] || i>p)
68       { 
69     if ((!color[t]) && (que[i-1]-que[t-1]>mlen)) { a=que[t-1];b=que[i-1];mlen=que[i-1]-que[t-1];}
70     t=i;
71       }
72   cout << a << ' ' << b << endl;
73   //system("pause");
74   return 0;
75 }
76 
個別目標遠大的同學可能并不僅僅是想解決這個題目,這時候建議你使用離散化+線段樹,復雜度會大大地降低

posted on 2009-07-20 15:00 Chen Jiecao 閱讀(443) 評論(0)  編輯 收藏 引用 所屬分類: URAL

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产真实精品久久二三区| 一区二区三区亚洲| 国产精品99久久不卡二区| 91久久中文| 欧美精选午夜久久久乱码6080| 亚洲精品国产品国语在线app| 亚洲欧洲在线免费| 欧美四级在线观看| 欧美在线一级视频| 久久av一区二区三区漫画| 在线播放国产一区中文字幕剧情欧美 | 亚洲欧美久久| 国产在线成人| 亚洲国产精品成人| 国产精品麻豆va在线播放| 欧美在线免费视屏| 久久网站免费| 在线亚洲免费| 久久爱www久久做| 亚洲精品极品| 亚洲自啪免费| 亚洲国产专区校园欧美| 一区二区欧美精品| 国产一区二区三区丝袜| 亚洲成人在线视频播放 | 欧美成人一区二区三区在线观看| 美日韩精品视频免费看| 亚洲午夜视频在线观看| 欧美在线啊v一区| 日韩手机在线导航| 午夜精品一区二区三区电影天堂 | 国产精品你懂的在线欣赏| 欧美自拍偷拍午夜视频| 蜜桃av综合| 小处雏高清一区二区三区| 久久免费黄色| 亚洲综合视频1区| 蜜臀av一级做a爰片久久| 亚洲尤物在线| 欧美大片在线观看一区二区| 欧美一级视频免费在线观看| 欧美www视频| 久久久水蜜桃av免费网站| 欧美日韩高清在线| 欧美阿v一级看视频| 国产乱码精品1区2区3区| 亚洲黄一区二区| 精品成人一区二区三区| 亚洲欧美在线免费观看| 一本色道**综合亚洲精品蜜桃冫| 久久精品女人天堂| 羞羞色国产精品| 欧美三区在线| 亚洲精品网站在线播放gif| 亚洲国产婷婷香蕉久久久久久99 | 欧美电影在线观看完整版| 国产精品亚洲综合久久| 野花国产精品入口| 日韩视频在线一区| 欧美成人精品福利| 欧美激情第一页xxx| 在线观看欧美精品| 久久九九国产精品| 久久久久久欧美| 国产字幕视频一区二区| 亚洲欧美欧美一区二区三区| 午夜视频久久久| 国产精品色婷婷| 亚洲欧美日韩国产中文| 午夜精品福利视频| 国产精品亚洲不卡a| 亚洲欧美久久久| 久久精品人人做人人综合| 国产色爱av资源综合区| 香蕉久久夜色| 美女免费视频一区| 亚洲国产精品久久人人爱蜜臀| 久久久一区二区| 欧美国产视频日韩| 99综合电影在线视频| 欧美日韩在线播放三区四区| 99在线观看免费视频精品观看| 亚洲免费视频观看| 国产欧美日韩伦理| 久久中文字幕一区二区三区| 亚洲国产午夜| 亚洲你懂的在线视频| 国产日韩一区二区| 久久久噜久噜久久综合| 欧美激情第五页| 亚洲一区二区动漫| 国产一区视频网站| 免费成人性网站| 亚洲精品久久久久久久久| 亚洲综合视频网| 伊人久久大香线蕉综合热线| 欧美sm视频| 亚洲男女自偷自拍| 欧美gay视频| 亚洲一区二区三区免费视频| 国产一区二区三区黄视频| 麻豆精品视频在线观看| 一本久道久久综合中文字幕| 久久夜色精品亚洲噜噜国产mv| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩国产综合视频在线| 午夜日韩电影| 亚洲免费观看高清完整版在线观看熊| 久久精品官网| 一区二区三区.www| 在线不卡视频| 国产精品每日更新| 欧美福利小视频| 欧美一区二区三区在线播放| 亚洲美女av网站| 欧美承认网站| 久久久97精品| 亚洲欧美清纯在线制服| 亚洲精品国产精品国自产在线 | 激情自拍一区| 国产精品黄色在线观看| 免费日韩成人| 久久国产精品久久久久久| 一区二区三区国产盗摄| 亚洲福利av| 欧美成va人片在线观看| 久久青青草综合| 欧美一区二区女人| 亚洲永久精品国产| 亚洲精品视频免费在线观看| 激情综合自拍| 国产一区二区日韩| 国产麻豆9l精品三级站| 欧美亚一区二区| 欧美午夜精品久久久久久久| 欧美激情 亚洲a∨综合| 美日韩精品免费| 久久蜜桃资源一区二区老牛 | 亚洲图色在线| 亚洲乱码国产乱码精品精天堂| 欧美激情1区2区3区| 欧美~级网站不卡| 欧美成人免费观看| 欧美顶级艳妇交换群宴| 免费成人在线观看视频| 裸体丰满少妇做受久久99精品| 久久久九九九九| 久久综合精品一区| 久久一综合视频| 你懂的网址国产 欧美| 欧美成人免费va影院高清| 欧美/亚洲一区| 亚洲第一久久影院| 亚洲日本黄色| 99re8这里有精品热视频免费| 一区二区三区 在线观看视频 | 久久男人av资源网站| 久久婷婷国产综合国色天香| 免费高清在线一区| 亚洲国产成人在线播放| 亚洲精选在线| 亚洲综合精品四区| 久久激情久久| 欧美激情a∨在线视频播放| 欧美日韩国产天堂| 国产伦精品一区二区三区免费迷| 国产嫩草一区二区三区在线观看| 国产亚洲毛片| 亚洲美女av黄| 新片速递亚洲合集欧美合集| 久久亚洲春色中文字幕| 欧美激情一区在线观看| 一区二区三区精密机械公司 | 久久嫩草精品久久久精品| 欧美激情欧美狂野欧美精品| 欧美午夜不卡视频| 黄色国产精品一区二区三区| 日韩亚洲一区在线播放| 欧美自拍丝袜亚洲| 亚洲第一页自拍| 午夜伦理片一区| 欧美极品在线播放| 国产亚洲精品久久久| 亚洲激情综合| 久久aⅴ国产欧美74aaa| 亚洲国产一成人久久精品| 亚洲一区二区视频| 免费一区视频| 国产日韩精品视频一区| 亚洲久色影视| 久久夜色精品国产欧美乱极品| 亚洲老板91色精品久久| 久久久999精品免费| 国产精品国产自产拍高清av| 亚洲高清视频在线| 欧美在线观看视频一区二区| 亚洲精选一区二区| 蜜桃av一区| 在线看成人片| 久久精品一区二区三区不卡|