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

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看| 欧美在线观看视频在线| 久久精品国产精品亚洲综合| 亚洲一区在线播放| 午夜精品www| 久久久久久综合| 欧美电影美腿模特1979在线看| 午夜在线一区二区| 久久av二区| 久久在线免费视频| 亚洲经典在线| 国产一区二区福利| 亚洲激情视频| 亚洲欧美综合网| 欧美肥婆bbw| 亚洲激情视频在线播放| 亚洲高清一二三区| 国产精品99久久久久久www| 欧美亚洲综合久久| 欧美激情一区在线观看| 亚洲午夜精品视频| 欧美xxx在线观看| 国产精品综合av一区二区国产馆| 黄色一区二区在线| 欧美伊久线香蕉线新在线| 亚洲电影视频在线| 欧美一区三区三区高中清蜜桃| 欧美视频一区二区在线观看 | 亚洲一区bb| 久热精品视频在线观看一区| 国产欧美va欧美va香蕉在| 亚洲日本欧美日韩高观看| 欧美国产在线电影| 激情成人中文字幕| 久久在线免费视频| 美女福利精品视频| 亚洲三级色网| 中文在线一区| 欧美激情亚洲视频| 久久九九国产精品| 亚洲激情亚洲| 一区二区三区视频观看| 国产精品入口麻豆原神| 久久嫩草精品久久久精品一| 久久黄色影院| 亚洲激情午夜| 亚洲摸下面视频| 亚洲国产精品123| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲欧美国产另类| 国产欧美日本一区二区三区| 欧美在线91| 久久伊人免费视频| 亚洲天堂久久| 久久久久久久精| 亚洲欧美中日韩| 久久一本综合频道| 久久精品国产欧美激情| 欧美精品在线免费| 欧美高清自拍一区| 国产一区二区三区的电影 | 一本色道久久综合亚洲二区三区| 亚洲精品在线观| 欧美伊人精品成人久久综合97| 一区二区三区免费网站| 久久资源av| 欧美jizzhd精品欧美喷水| 国产亚洲欧洲| 久久成人综合视频| 欧美精品电影| 久久久久高清| 一区精品久久| 久久另类ts人妖一区二区| 久久久久久一区二区| 国产在线高清精品| 噜噜噜噜噜久久久久久91 | 亚洲精品乱码视频| 亚洲国内精品| 欧美日韩免费区域视频在线观看| 亚洲欧洲另类国产综合| 亚洲桃花岛网站| 国产一区二区精品丝袜| 欧美在线观看视频一区二区三区| 久久久久9999亚洲精品| 狠狠狠色丁香婷婷综合久久五月| 久久不射电影网| 99精品免费网| 蜜臀va亚洲va欧美va天堂| 一本大道久久a久久精二百| 欧美视频精品在线观看| 久久精品国产77777蜜臀| 亚洲精品一区在线观看香蕉| 久久久久网站| 亚洲综合色视频| 亚洲精品激情| 美国成人直播| 欧美在线观看视频| 久久婷婷亚洲| 亚洲一级免费视频| 国产精品久久久久高潮| 欧美亚洲一级| 日韩午夜电影在线观看| 久久伊人亚洲| 香蕉久久精品日日躁夜夜躁| 一区二区三区视频免费在线观看| 国产亚洲视频在线| 国产精品乱码一区二区三区| 欧美成人嫩草网站| 久久综合中文色婷婷| 久久久国产亚洲精品| 久久国产手机看片| 久久激情综合| 久久这里只有| 欧美刺激午夜性久久久久久久| 久久综合色88| 欧美激情免费在线| 国产精品扒开腿爽爽爽视频| 欧美性做爰毛片| 娇妻被交换粗又大又硬视频欧美| 国内久久精品| 亚洲精品一区二区三区在线观看| 亚洲国产精品www| 亚洲国产日韩一区| 亚洲午夜日本在线观看| 亚洲欧美伊人| 亚洲国产成人精品视频| 91久久精品国产| 欧美一级淫片aaaaaaa视频| 久久婷婷国产综合精品青草| 欧美精品一区二区三区蜜桃| 国产精品久久久久久户外露出| 国产情人节一区| 亚洲一区二区欧美日韩| 美国十次了思思久久精品导航| 欧美日韩国产成人在线91| 国内成人精品视频| 亚洲视频你懂的| 国产精品久久久久aaaa| 欧美一区二区三区在线看| 亚洲精品五月天| 蜜桃视频一区| 久久久久久69| 国产欧亚日韩视频| 欧美福利一区| 国产一区二区三区精品欧美日韩一区二区三区| 又紧又大又爽精品一区二区| 欧美影院在线| 久久婷婷国产麻豆91天堂| 国产精品欧美日韩一区二区| 欧美一级视频| 蜜桃av一区二区| 亚洲自拍电影| 久久精品卡一| 伊人成人开心激情综合网| 久久三级福利| 久久国产乱子精品免费女| 国产日韩精品视频一区二区三区| 亚洲自拍偷拍一区| 亚洲欧美日韩成人| 亚洲国产欧美日韩| 久久国产视频网站| 亚洲深夜福利视频| 欧美一区二区在线视频| 久久精品国产欧美亚洲人人爽| 一本一本a久久| 欧美精品福利| 亚洲人成亚洲人成在线观看图片 | 亚洲国产婷婷香蕉久久久久久| 美女爽到呻吟久久久久| 欧美成人免费va影院高清| 亚洲女优在线| 久久蜜桃精品| 香蕉久久国产| 国产永久精品大片wwwapp| 亚洲在线中文字幕| 欧美在线看片a免费观看| 欧美精品一区视频| 亚洲欧洲免费视频| 亚洲视频在线观看网站| 欧美成人一区二区三区| 亚洲视频二区| 欧美国产一区二区| 美女精品网站| 国产日产精品一区二区三区四区的观看方式 | 亚洲国产三级在线| 亚洲国产天堂久久综合网| 欧美精品三级在线观看| 99视频有精品| 狼狼综合久久久久综合网| 99精品福利视频| 国产伦精品一区二区| 欧美精品成人| 欧美黄色一级视频| 久久综合五月| 日韩视频专区| 亚洲免费观看高清在线观看|