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

Why so serious? --[NKU]schindlerlee

2010年03月28日星期日.codeforces beta6

2010年03月28日星期日.codeforces beta6

A:三角形兩邊之和大于第三邊
B:暴力搜一下
C:模擬

?1?
?2?scanf("%d\n",&n);
?3?for?(i?=?0;i?<?n;i++)?{
?4???scanf("%d",a?+?i);
?5?}
?6?int?L?=?0,R?=?n?-?1,time1?=?0,time2?=?0,ans1?=?0,ans2?=?0;
?7?while?(L?<=?R)?{
?8???if?(time1?<?time2)?{
?9???????time1?+=?a[L++]?,ans1?++;
10???}else?if?(time1?>?time2)?{
11???????time2?+=?a[R--]?,ans2?++;
12???}else?{
13???????time1?+=?a[L++]?,ans1?++;
14???}
15?}
16?printf("%d?%d\n",ans1,ans2);

D:題目改了,和比賽的時候不一樣了,數據范圍很小,dfs
E:RMQ + binary_search
給出n個數和一個范圍K。
找出最長的連續的數,其中最大值和最小值的差不超過K
一個直覺的想法是
for(i = 0;i < n;i++) {
?? ?int L = a[i],R = a[i];
?? ?for (j = i + 1;j < n && R - L <= K;j++) {
?? ??? ?更新L,R
?? ?}
?? ?更新answer
}

但是n是10^5,n^2會超時。
求區間最大值最小值可以用rmq,O(nlogn)預處理,O(1)的得到。
一定存在一個j,使得a [i ... j]合法,a[j + 1 ..n]不合法。
好的方法是二分搜索到這個j,水點的方法可以從后往前找j。

RMQ 可以線段樹,也可以SparseTable
總復雜度O(nlogn)
codeforces 可以看代碼,想看的會去找吧。這里的二分搜有trick,求的是upper_bound不是一般寫的lower_bound,需要調整。

posted on 2010-03-28 01:17 schindlerlee 閱讀(1581) 評論(3)  編輯 收藏 引用 所屬分類: 解題報告

Feedback

# re: 2010年03月28日星期日.codeforces beta6 2010-03-28 07:54 MasterLuo

我覺得E二分是會有問題的?并不滿足單調性。
我有個想法就是用二條掃描線,外加一個最小堆來維護。  回復  更多評論   

# re: 2010年03月28日星期日.codeforces beta6 2010-03-28 10:08 schindlerlee

@MasterLuo
我覺得是單調的,肯定是前邊合法,后邊不合法了
還有就是我相信sgu那幫人做的動不動上百組的測試數據...
另外,我不太明白你說的掃描,我感覺那樣豈不是n^2了?


 1 for (i = 0;i < n;i++) {
 2     int L = i,R = n;
 3     while (L < R) {
 4         int mid = (L + R) / 2;
 5         int tmp = bigrmq(i,mid) - smlrmq(i,mid);
 6         if (tmp <= diff) {
 7             if (L == mid) { break;}
 8             L = mid;
 9         }else {
10             if (R == mid + 1) {break;}
11             R = mid + 1;
12         }
13     }
14     int tmp = L - i + 1;
15     if (tmp > ans) {
16         ans = tmp;
17         記錄結果
18     }else if (tmp == ans) {
19         記錄結果
20     }
21 }


  回復  更多評論   

# re: 2010年03月28日星期日.codeforces beta6 2010-03-28 10:48 MasterLuo

@schindlerlee
掃描是NlogN的,因為我們從第一個開始每加入一個數后如果引起了不滿足題意條件,那么一定是最新加入的那個數引起的,現在還在堆中的最大數與最小數之間一定會有一個要退出,可以證明它與后面要加入的數也不能滿足條件。于是我們找到位置在前面的那個數,把它前面所有的數都刪除。再判斷,直到滿足條件為止。這樣每個數就只進優先隊列一次,也只出優先隊列一次。 我寫了下代碼,驗證了一下,過上去過了。
C++語言: 臨時自用代碼


int n, k, maxVal, minVal;
int arr[100000], ans = 0, maxLen = 1, red[100000][2];
struct Node {
int loc, val;
}node;
struct CMP_1 {
bool operator()(const Node& min, const Node& max) {
if((min.val > max.val) ||(min.val == max.val && min.loc > max.loc))
return true;
return false;
}
};
struct CMP_2 {
bool operator()(const Node& min, const Node& max) {
if((min.val < max.val) || (min.val == max.val && min.loc > max.loc))
return true;
return false;
}
};
int last = 0;
int main() {
scanf("%d %d", &n, &k);
for(int i = 0; i < n; ++i) {
scanf("%d", &arr[i]);
}
priority_queue<Node, vector<Node>, CMP_1> pri;
priority_queue<Node, vector<Node>, CMP_2> pri2;

for(int i = 0; i < n; ++i) {
node.val = arr[i];
node.loc = i;
pri.push(node);
pri2.push(node);

int minVal = pri.top().val;
int maxVal = pri2.top().val;

while(maxVal - minVal > k) {
int lt = min(pri.top().loc, pri2.top().loc);
while(!pri.empty() && pri.top().loc <= lt) {
pri.pop();
}
while(!pri2.empty() && pri2.top().loc <= lt) {
pri2.pop();
}
last = lt + 1;
minVal = pri.top().val;
maxVal = pri2.top().val;
}
int tmpLen = i - last + 1;
if(tmpLen == maxLen) {
red[ans][0] = last;
red[ans][1] = i;
++ans;
}
if(tmpLen > maxLen) {
red[0][0] = last;
red[0][1] = i;
ans = 1;
maxLen = tmpLen;
}
}
printf("%d %d\n", maxLen, ans);
for(int i = 0; i < ans; ++i) {
printf("%d %d\n", red[i][0] + 1, red[i][1] + 1);
}
return 0;
}

  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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王其| 国产精品久久激情| 国产自产在线视频一区| 亚洲福利视频网站| 一本一本久久a久久精品综合妖精| 亚洲美女网站| 亚洲欧美日韩综合aⅴ视频| 欧美在线观看视频在线| 久久躁日日躁aaaaxxxx| 亚洲国产精品成人综合色在线婷婷| 亚洲国产精品ⅴa在线观看| 日韩视频免费在线观看| 亚洲综合日韩| 久久综合狠狠综合久久综青草 | 久色成人在线| 欧美va天堂在线| 国产精品久久久久久久久久久久久 | 欧美紧缚bdsm在线视频| 欧美精品久久久久久久免费观看 | 欧美成人免费在线观看| 国产精品国产三级国产a| 狠狠88综合久久久久综合网| 亚洲乱码国产乱码精品精天堂 | 亚洲精品一区二区三区不| 一区二区精品| 久久久精品动漫| 亚洲黄一区二区三区| 午夜欧美电影在线观看| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美午夜影院| 亚洲区中文字幕| 久久漫画官网| 亚洲网址在线| 欧美精品午夜视频| 羞羞答答国产精品www一本| 一本一本久久a久久精品牛牛影视| 美女黄网久久| 宅男在线国产精品| 久久精品理论片| 欧美日韩亚洲一区二区三区在线观看 | 国产乱码精品1区2区3区| 黄色精品一二区| 一区二区av在线| 欧美大片免费久久精品三p | 欧美韩日亚洲| 亚洲欧美影院| 国产精品永久免费在线| 亚洲综合三区| 亚洲三级免费观看| 欧美国产免费| 91久久一区二区| 欧美精品激情在线观看| 亚洲人成毛片在线播放| 欧美国产日产韩国视频| 久久国产欧美精品| 国产最新精品精品你懂的| 亚洲欧美国产高清va在线播| 99国产精品久久久久老师| 欧美日韩另类一区| 亚洲欧美国内爽妇网| 国产精品99久久久久久白浆小说| 欧美日韩直播| 午夜精品久久99蜜桃的功能介绍| 中文在线一区| 国产欧美一区二区三区另类精品 | 性欧美videos另类喷潮| 一区二区欧美亚洲| 欧美电影免费| 一本色道久久综合一区| 亚洲综合不卡| 亚洲成色777777女色窝| 欧美日韩在线大尺度| 亚洲一区二区免费| 久久精品久久综合| 亚洲国产欧美一区二区三区丁香婷| 欧美一区二区三区四区视频| 欧美视频在线看| 亚洲欧美日韩综合一区| 香蕉久久夜色精品| 亚洲国产午夜| 一区二区三区四区蜜桃| 国产精品久久久| 久久婷婷国产麻豆91天堂| 麻豆国产精品777777在线| 日韩视频永久免费| 亚洲自拍三区| 在线观看视频一区二区| 日韩视频免费在线| 韩国成人福利片在线播放| 亚洲国产欧美日韩| 久久综合伊人77777麻豆| 蜜乳av另类精品一区二区| 在线视频一区观看| 欧美在线播放一区二区| 亚洲精品中文字幕女同| 亚洲欧美久久久| 亚洲免费成人av电影| 欧美一区二区三区免费看| 亚洲精品小视频在线观看| 欧美一区综合| 国产精品99久久99久久久二8| 欧美亚洲日本一区| av不卡在线| 久久精品成人一区二区三区| 99热这里只有精品8| 久久激五月天综合精品| 亚洲欧美久久久| 欧美美女bb生活片| 欧美成人免费网站| 国产综合视频| 亚洲一区二区影院| 亚洲网站在线播放| 欧美成熟视频| 免费中文字幕日韩欧美| 国产视频久久网| 亚洲女爱视频在线| 亚洲在线不卡| 欧美午夜寂寞影院| 亚洲另类在线视频| 99精品欧美一区二区三区综合在线 | 欧美三级欧美一级| 亚洲电影免费观看高清完整版| 国产日韩亚洲欧美综合| 一区二区精品在线| 一区二区日韩伦理片| 免费永久网站黄欧美| 久久综合影视| 一区二区在线观看av| 久久国产精品电影| 可以看av的网站久久看| 激情亚洲网站| 久久精品九九| 99pao成人国产永久免费视频| 亚洲一级片在线观看| 亚洲国产裸拍裸体视频在线观看乱了| 欧美午夜不卡在线观看免费 | 国产欧美日韩激情| 艳女tv在线观看国产一区| 欧美激情亚洲精品| 欧美激情久久久久| 亚洲精品免费一区二区三区| 美女亚洲精品| 亚洲激情第一页| 一本色道久久综合亚洲精品小说| 欧美日韩亚洲高清| 亚洲制服欧美中文字幕中文字幕| 午夜一区在线| 黄色综合网站| 欧美国产日本在线| 一区二区三区欧美激情| 性色一区二区三区| 一区福利视频| 欧美精品一区三区| 亚洲自拍偷拍麻豆| 欧美www视频| 国产精品99久久久久久白浆小说| 国产精品久久999| 午夜免费在线观看精品视频| 免费日韩视频| 亚洲永久视频| 伊人天天综合| 欧美日韩免费看| 午夜亚洲福利在线老司机| 欧美v亚洲v综合ⅴ国产v| 亚洲影视在线播放| 精品成人一区二区三区| 欧美日韩成人一区二区| 亚欧成人精品| 亚洲欧洲精品一区二区三区波多野1战4| 一区二区三区欧美激情| 国产视频一区二区在线观看| 欧美1区2区| 欧美一级网站| 日韩视频精品| 欧美黄色精品| 久久精品91久久久久久再现| 亚洲精品视频在线看| 国产一区二区成人| 欧美肉体xxxx裸体137大胆| 欧美亚洲三区| 亚洲少妇最新在线视频| 欧美高清你懂得| 久久久精品2019中文字幕神马| 一区二区三区国产精华| 伊人一区二区三区久久精品| 国产欧美日韩免费看aⅴ视频| 欧美日本在线视频| 久久夜色精品国产噜噜av| 亚洲一区bb| 日韩亚洲欧美中文三级|