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

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>
            亚洲美女av网站| 欧美激情四色 | 欧美精品日本| av成人国产| 欧美一区二区三区视频在线观看| 国产精品私人影院| 久久精品视频网| 亚洲人成亚洲人成在线观看图片 | 欧美 日韩 国产在线| 亚洲欧洲精品一区二区三区 | 亚洲三级电影全部在线观看高清| 欧美激情久久久| 亚洲视频在线观看一区| 久久久久久成人| 亚洲精品在线免费| 国产精品久久久久久久久动漫 | 国产精品一区免费视频| 久久精品亚洲热| 亚洲乱码国产乱码精品精天堂| 亚洲欧美视频一区二区三区| 狠色狠色综合久久| 欧美日韩国产小视频在线观看| 性欧美1819性猛交| 亚洲激情视频网| 久久精品卡一| 99视频有精品| 国产主播一区二区| 欧美日韩在线综合| 久久精品一区二区三区不卡| 日韩视频在线永久播放| 看片网站欧美日韩| 亚洲一区国产精品| 亚洲国产精品精华液2区45| 国产精品日韩在线一区| 美女黄色成人网| 欧美一区二区三区四区在线 | 亚洲一区二区精品视频| 亚洲电影免费观看高清| 久久精品免费| 午夜国产精品视频免费体验区| 在线观看欧美黄色| 国产女主播一区| 欧美日韩一二三区| 欧美a级大片| 久久精品水蜜桃av综合天堂| 亚洲一区二区三区在线观看视频| 亚洲第一精品夜夜躁人人躁| 久久男人资源视频| 欧美中文在线观看| 亚洲欧美国产日韩中文字幕| 亚洲精品一区二区三区婷婷月| 韩国免费一区| 国产欧美日韩在线| 国产精品美女久久久免费| 欧美精品在线观看一区二区| 噜噜噜噜噜久久久久久91| 久久av一区二区三区| 亚洲男女自偷自拍| 一区二区三区四区五区精品| 亚洲精品激情| 亚洲精品欧洲| 最近看过的日韩成人| 亚洲福利国产| 最新精品在线| 亚洲欧洲日本专区| 亚洲激情影视| 亚洲精品免费在线播放| 亚洲黄色成人久久久| 亚洲高清中文字幕| 亚洲激情视频| 亚洲美女91| 亚洲网在线观看| 亚洲男人影院| 欧美亚洲综合在线| 久久av老司机精品网站导航| 久久久999国产| 久久久一二三| 欧美国产精品v| 欧美精品在线看| 国产精品福利在线观看| 国产精品久久久99| 国产欧美综合在线| 黄页网站一区| 亚洲美女av在线播放| 一区二区三区高清| 午夜精品久久久久久久蜜桃app | 夜夜精品视频| 亚洲一区二区3| 欧美怡红院视频| 久久久综合精品| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久婷婷国产麻豆91天堂| 久久亚洲综合| 亚洲国产导航| 亚洲午夜精品一区二区三区他趣| 亚洲免费网址| 久久最新视频| 欧美婷婷久久| 国产在线不卡视频| 亚洲人被黑人高潮完整版| 亚洲小视频在线| 久久精品中文字幕免费mv| 女女同性精品视频| 99亚洲伊人久久精品影院红桃| 亚洲欧美日韩网| 免费久久精品视频| 国产精品久久91| 在线精品国精品国产尤物884a| 日韩亚洲国产精品| 欧美在线一级va免费观看| 欧美激情一区二区三区全黄| 一本久久综合亚洲鲁鲁| 性久久久久久| 欧美日韩国产成人在线| 国产亚洲视频在线| 一区二区三区福利| 久久午夜电影| 正在播放日韩| 欧美不卡在线| 国产一区二区中文字幕免费看| 亚洲美女精品成人在线视频| 久久精品国产清高在天天线 | 欧美在线视频二区| 亚洲韩国青草视频| 先锋影音国产精品| 欧美日韩成人综合在线一区二区| 国产曰批免费观看久久久| 一区二区三区日韩欧美| 猫咪成人在线观看| 亚洲午夜激情网页| 欧美精品激情在线| 在线播放日韩| 欧美一区日韩一区| 999在线观看精品免费不卡网站| 久久久xxx| 国产精品日韩欧美综合| 夜夜嗨一区二区| 欧美大片在线观看| 欧美一级淫片aaaaaaa视频| 欧美日韩午夜精品| 亚洲精品久久久蜜桃| 久久综合色88| 欧美在线1区| 国产欧美精品一区| 亚洲综合社区| 亚洲久色影视| 欧美国产日韩一二三区| 在线观看中文字幕亚洲| 久久久久久国产精品mv| 亚洲欧美一区二区三区久久| 国产精品啊啊啊| 亚洲午夜精品一区二区| 亚洲精品欧美在线| 欧美另类69精品久久久久9999| 亚洲国产精品黑人久久久| 老司机久久99久久精品播放免费| 午夜在线a亚洲v天堂网2018| 国产精品午夜电影| 午夜久久久久久| 亚洲一区二区三区四区视频| 欧美日韩在线播放一区| 在线亚洲一区二区| 亚洲免费福利视频| 欧美日韩亚洲激情| 亚洲视屏在线播放| 一本色道久久综合亚洲精品小说| 欧美日韩你懂的| 亚洲午夜精品视频| 亚洲无限乱码一二三四麻| 国产精品红桃| 欧美中文在线字幕| 久久成人国产| 亚洲电影一级黄| 欧美大片一区二区三区| 欧美jizz19性欧美| 一本色道久久88综合亚洲精品ⅰ | 在线观看亚洲视频| 欧美国产激情| 欧美日韩精品免费观看视频完整 | 欧美日韩调教| 亚洲欧美久久久| 欧美亚洲一区二区三区| 激情视频一区二区三区| 欧美jizz19性欧美| 欧美日韩成人综合天天影院| 亚洲男女毛片无遮挡| 性欧美大战久久久久久久免费观看| 国产主播在线一区| 欧美激情综合| 国产精品成人在线观看| 久久精品视频在线看| 久久综合狠狠综合久久激情| 亚洲伦理自拍| 亚洲综合第一| 亚洲电影在线| 99在线热播精品免费99热| 国产欧美日韩亚洲精品| 欧美成人综合| 国产精品久久久久久亚洲毛片 | 国产偷久久久精品专区|