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

oyjpArt ACM/ICPC算法程序設計空間

// I am new in programming, welcome to my blog
I am oyjpart(alpc12, 四城)
posts - 224, comments - 694, trackbacks - 0, articles - 6
Minimizing maximizer
Time Limit: 5000MS Memory Limit: 30000K
Total Submissions: 1004 Accepted: 280

Description
The company Chris Ltd. is preparing a new sorting hardware called Maximizer. Maximizer has n inputs numbered from 1 to n. Each input represents one integer. Maximizer has one output which represents the maximum value present on Maximizer's inputs.

Maximizer is implemented as a pipeline of sorters Sorter(i1, j1), ... , Sorter(ik, jk). Each sorter has n inputs and n outputs. Sorter(i, j) sorts values on inputs i, i+1,... , j in non-decreasing order and lets the other inputs pass through unchanged. The n-th output of the last sorter is the output of the Maximizer.

An intern (a former ACM contestant) observed that some sorters could be excluded from the pipeline and Maximizer would still produce the correct result. What is the length of the shortest subsequence of the given sequence of sorters in the pipeline still producing correct results for all possible combinations of input values?

Task
Write a program that:

reads a description of a Maximizer, i.e. the initial sequence of sorters in the pipeline,
computes the length of the shortest subsequence of the initial sequence of sorters still producing correct results for all possible input data,
writes the result.

Input
The first line of the input contains two integers n and m (2 <= n <= 50000, 1 <= m <= 500000) separated by a single space. Integer n is the number of inputs and integer m is the number of sorters in the pipeline. The initial sequence of sorters is described in the next m lines. The k-th of these lines contains the parameters of the k-th sorter: two integers ik and jk (1 <= ik < jk <= n) separated by a single space.

Output
The output consists of only one line containing an integer equal to the length of the shortest subsequence of the initial sequence of sorters still producing correct results for all possible data.

Sample Input

40 6
20 30
1 10
10 20
20 30
15 25
30 40

 

Sample Output

4

 

Hint
Huge input data, scanf is recommended.

Source
Central Europe 2003

//pku1769
/*
 * trival DP dp[i] = dp[j] + 1 (if there is a segment starting from a->i && a <= j)  o(n^2)
 * 考慮到轉移的時候選擇的是一段內的最小dp值,運用點樹可以解決
 */
#include <string.h>
#include <stdio.h>

const int N = 50010;
const int MAXINT = 1000000000;

int n, l;

struct ST {int i,j,m,l,r,c;} st[2*N];
int up, cnt;

void bd(int d, int x, int y) {
 st[d].i = x, st[d].j = y, st[d].m = (x+y)/2, st[d].c = MAXINT;
 if(x < y) {
  st[d].l = ++up; bd(up, x, st[d].m);
  st[d].r = ++up; bd(up, st[d].m+1, y);
 }
}

void ins(int d, int x, int c) {
 if(c < st[d].c)
  st[d].c = c;
 if(st[d].i != st[d].j) {
  if(x <= st[d].m)
   ins(st[d].l, x, c);
  else
   ins(st[d].r, x, c);
 }
}

int getmin(int d, int x, int y) {
 if(x <= st[d].i && y >= st[d].j)
  return st[d].c;
 int min = MAXINT;
 if(x <= st[d].m) {
  int now = getmin(st[d].l, x, y);
  if(now < min) min = now;
 }
 if(y > st[d].m) {
  int now = getmin(st[d].r, x, y);
  if(now < min) min = now;
 }
 return min;
}

int main() {
 int i, a, b;
 up = 0;
 scanf("%d %d ", &l, &n);
 bd(0, 1, l);
 ins(0, 1, 0);
 int max = 0;
 for(i = 0; i < n; ++i) {
  scanf("%d%d", &a, &b);
  if(a < b) {
   int min = getmin(0, a, b-1);
   ins(0, b, min+1);
  }
 }
 printf("%d\n", getmin(0, l, l));
 return 0;
}

Feedback

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2007-12-04 16:33 by je
題目沒看懂,能解釋下么?

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2007-12-05 11:47 by oyjpart
給定一個線段集,要求選擇其中一個最小的子集來覆蓋整個區域。
要求選定的子集是按照題目給的序來覆蓋。

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-01-18 08:46 by Littleye
很多測試好像得不到正確答案,例如:
40 4
10 30
14 29
25 30
30 40
答案應該是2,你的程序給的是1000000000(你的初始值)
類似的例子還有不少

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-01-18 12:40 by oyjpart
你的樣例是無解的,沒有線段覆蓋【0,10】的區間。

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-01-19 02:33 by Littleye
I understand now. I don't think I understood the problem thoroughly before. Although the problem description doesn't clearly indicate that all the segments given should cover the whole segment(1,N), it is the right situation or else we can't get the right output from the maximizer. Now the problem description says that we can get the right output, so the subsequences given must cover the whole segments. Thanks a lot!

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-01-19 12:34 by oyjpart
you are welcome

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-04-18 10:44 by l-y-p
向大牛學習學習,“運用點樹可以解決”,好思想,很好很強大。但是還有一個疑點:在DP的時候應該從小到大進行,但是沒發現你對y坐標進行排序就直接進行,那如果是考慮這樣兩組數據:
10 40
0 10
從10到40先確定到40的DP值為maxint+1,然后再由0~10確定10的值為1,這樣是不是有問題??你的程序我沒調試過,不曉得你是怎么處理的?

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-04-18 10:58 by l-y-p
果然啊,剛調試了下,直接運行數據:
40 2
10 40
0 10
結果是1000000000,不知道是我沒看清楚還是程序的bug?

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-04-18 12:19 by oyjpart
題目是有這樣的要求的:
要求選定的子集是按照題目給的序來覆蓋。
嘿嘿 如果我沒有理解錯你的意思的話

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2008-04-18 22:02 by l-y-p
汗!
What is the length of the shortest subsequence of the given sequence of sorters
把排序一去掉就AC了,多謝大牛指點,呵呵。
最先還一直在想如果可以排序的話就用不著用點樹了,直接貪心!

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2009-08-25 10:39 by demo
你的程序過不了zoj 2451

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2009-09-07 23:58 by oyjpart
題目是一樣的嗎

# re: pku1769 新寫的線段樹(點樹)模版  回復  更多評論   

2010-12-01 20:36 by LSK
請仔細讀題。。。ZJU哪個是multi case的
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久成人在线| 久久久久9999亚洲精品| 欧美电影电视剧在线观看| 在线精品观看| 欧美激情亚洲视频| 欧美日本在线视频| 午夜日本精品| 久久久久久高潮国产精品视| 亚洲成在线观看| 亚洲欧洲日产国码二区| 欧美乱人伦中文字幕在线| 亚洲自拍偷拍一区| 欧美在线观看视频在线| 亚洲欧洲一区二区天堂久久 | 一区免费观看| 欧美激情在线狂野欧美精品| 欧美日韩国产大片| 欧美一区二区三区视频免费播放| 欧美在线视频二区| 亚洲免费精品| 亚洲欧美日韩另类| 亚洲精品女人| 欧美一区亚洲二区| 亚洲精品色图| 久久精品30| 中文日韩电影网站| 久久久免费观看视频| 亚洲视频免费| 久久麻豆一区二区| 亚洲综合色婷婷| 欧美69视频| 久久精品国产久精国产爱| 欧美精品福利在线| 久久久精彩视频| 欧美性猛交视频| 亚洲国产va精品久久久不卡综合| 国产精品毛片高清在线完整版| 欧美日韩小视频| 久久综合伊人77777蜜臀| 国产精品mm| 亚洲国产精品嫩草影院| 韩日欧美一区二区三区| 亚洲视屏在线播放| 亚洲精品五月天| 葵司免费一区二区三区四区五区| 亚洲欧美经典视频| 欧美日本精品在线| 亚洲福利视频在线| 在线看片日韩| 久久精品主播| 久久久久久综合| 国产视频亚洲| 亚洲一区二区三区在线看| 99香蕉国产精品偷在线观看| 久久午夜电影网| 久久综合狠狠综合久久综合88 | 国产精品日韩在线| 亚洲伦理网站| 日韩午夜精品| 欧美精品一区二区久久婷婷| 欧美黄色免费网站| 亚洲黄色在线| 欧美国产一区二区三区激情无套| 美女性感视频久久久| 国内成人精品视频| 久久精品五月婷婷| 美女91精品| 亚洲啪啪91| 欧美激情成人在线视频| 亚洲黄色小视频| 一区二区三区 在线观看视频| 欧美精品在线视频观看| 亚洲精品一区二区三区福利| 一区二区三区欧美在线观看| 欧美日韩免费一区二区三区视频| 亚洲精品专区| 亚洲欧美日韩天堂| 国产一区二区三区精品欧美日韩一区二区三区 | 蜜桃av一区| 亚洲激情一区二区| 欧美日韩一区二区三区四区五区| 日韩视频在线观看免费| 亚洲一区精品在线| 国产精品午夜视频| 久久精品99国产精品日本| 欧美 日韩 国产一区二区在线视频 | 日韩午夜激情av| 国产精品扒开腿做爽爽爽软件 | 免播放器亚洲一区| 日韩天天综合| 国产精品视频yy9099| 久久精品国产一区二区电影| 亚洲高清不卡一区| 午夜精品成人在线视频| 狠狠色伊人亚洲综合网站色| 欧美高清在线观看| 午夜国产精品视频| 欧美激情成人在线视频| 亚洲欧美春色| 亚洲大黄网站| 国产精品伦一区| 免费欧美在线视频| 亚洲欧美影音先锋| 亚洲黄色在线观看| 久久久久九九九| 一区二区精品在线| 一区二区视频欧美| 国产精品高潮呻吟久久| 另类激情亚洲| 午夜在线一区| 亚洲精品一区中文| 美女脱光内衣内裤视频久久网站| 亚洲视频在线观看免费| 在线成人h网| 欧美一区二区在线免费播放| 亚洲国产日韩在线| 久久亚洲国产精品一区二区| 亚洲欧美另类中文字幕| 亚洲精品久久7777| 国内外成人免费激情在线视频网站 | 日韩视频不卡中文| 亚洲第一狼人社区| 麻豆精品精品国产自在97香蕉| 亚洲视频在线观看免费| 亚洲精品欧美精品| 亚洲国产另类久久精品| 国产一区二区三区在线观看视频| 欧美午夜电影完整版| 欧美激情视频在线播放| 老牛嫩草一区二区三区日本| 欧美一二区视频| 亚洲欧美制服另类日韩| 中日韩在线视频| 日韩午夜在线视频| 亚洲精品综合| 亚洲精品国产精品国自产观看| 欧美高清一区| 亚洲第一视频| 亚洲高清123| 亚洲国产小视频在线观看| 欧美激情精品久久久六区热门 | 亚洲天堂黄色| 一道本一区二区| 中国av一区| 亚洲欧美中文日韩v在线观看| 在线一区日本视频| 亚洲欧美国产另类| 欧美一区二区视频网站| 久久久久久久久久久久久9999| 久久激情综合| 久久久亚洲成人| 欧美成人精品一区| 欧美激情一区二区三区高清视频| 欧美精品激情blacked18| 欧美日韩免费一区二区三区| 欧美日韩在线大尺度| 国产精品人人做人人爽| 国产亚洲女人久久久久毛片| 激情视频一区| 日韩视频在线免费观看| 亚洲特级毛片| 久久久蜜桃一区二区人| 欧美阿v一级看视频| 亚洲欧洲中文日韩久久av乱码| 日韩一级大片| 午夜影院日韩| 欧美成人免费大片| 国产精品www网站| 国产一区二区三区奇米久涩| 亚洲国产午夜| 午夜精品福利在线| 噜噜噜91成人网| 一本色道88久久加勒比精品 | 亚洲欧美日韩一区在线| 欧美在线二区| 欧美日本成人| 国语自产在线不卡| 日韩一级视频免费观看在线| 欧美亚洲专区| 亚洲成人在线免费| 欧美凹凸一区二区三区视频| 日韩一区二区精品在线观看| 午夜伦欧美伦电影理论片| 蜜桃伊人久久| 国产精品一区二区视频| 亚洲经典在线| 久久国产天堂福利天堂| 亚洲精品女av网站| 亚洲一区中文字幕在线观看| 欧美aa在线视频| 国内成人精品2018免费看 | 国产在线播放一区二区三区| 亚洲区在线播放| 久久一二三区| 亚洲一品av免费观看| 欧美成人免费全部| 精品999成人| 欧美伊久线香蕉线新在线| 亚洲人成亚洲人成在线观看图片| 欧美中文在线视频|