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

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:題目改了,和比賽的時(shí)候不一樣了,數(shù)據(jù)范圍很小,dfs
E:RMQ + binary_search
給出n個(gè)數(shù)和一個(gè)范圍K。
找出最長(zhǎng)的連續(xù)的數(shù),其中最大值和最小值的差不超過(guò)K
一個(gè)直覺(jué)的想法是
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會(huì)超時(shí)。
求區(qū)間最大值最小值可以用rmq,O(nlogn)預(yù)處理,O(1)的得到。
一定存在一個(gè)j,使得a [i ... j]合法,a[j + 1 ..n]不合法。
好的方法是二分搜索到這個(gè)j,水點(diǎn)的方法可以從后往前找j。

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

posted on 2010-03-28 01:17 schindlerlee 閱讀(1577) 評(píng)論(3)  編輯 收藏 引用 所屬分類(lèi): 解題報(bào)告

Feedback

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

我覺(jué)得E二分是會(huì)有問(wèn)題的?并不滿(mǎn)足單調(diào)性。
我有個(gè)想法就是用二條掃描線(xiàn),外加一個(gè)最小堆來(lái)維護(hù)。  回復(fù)  更多評(píng)論   

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

@MasterLuo
我覺(jué)得是單調(diào)的,肯定是前邊合法,后邊不合法了
還有就是我相信sgu那幫人做的動(dòng)不動(dòng)上百組的測(cè)試數(shù)據(jù)...
另外,我不太明白你說(shuō)的掃描,我感覺(jué)那樣豈不是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         記錄結(jié)果
18     }else if (tmp == ans) {
19         記錄結(jié)果
20     }
21 }


  回復(fù)  更多評(píng)論   

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

@schindlerlee
掃描是NlogN的,因?yàn)槲覀儚牡谝粋€(gè)開(kāi)始每加入一個(gè)數(shù)后如果引起了不滿(mǎn)足題意條件,那么一定是最新加入的那個(gè)數(shù)引起的,現(xiàn)在還在堆中的最大數(shù)與最小數(shù)之間一定會(huì)有一個(gè)要退出,可以證明它與后面要加入的數(shù)也不能滿(mǎn)足條件。于是我們找到位置在前面的那個(gè)數(shù),把它前面所有的數(shù)都刪除。再判斷,直到滿(mǎn)足條件為止。這樣每個(gè)數(shù)就只進(jìn)優(yōu)先隊(duì)列一次,也只出優(yōu)先隊(duì)列一次。 我寫(xiě)了下代碼,驗(yàn)證了一下,過(guò)上去過(guò)了。
C++語(yǔ)言: 臨時(shí)自用代碼


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;
}

  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久久一区欧美| 欧美黄色成人网| 99视频一区二区三区| 亚洲香蕉成视频在线观看| 亚洲欧美成人在线| 麻豆精品精品国产自在97香蕉| 欧美精品一区二区三区一线天视频| 欧美午夜宅男影院在线观看| 国模精品娜娜一二三区| 亚洲美洲欧洲综合国产一区| 午夜精品久久久久| 欧美jizz19性欧美| 亚洲一区二区动漫| 美女精品国产| 欧美视频在线一区二区三区| 国产丝袜一区二区三区| 亚洲伦理一区| 久久久精品网| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 免费在线看一区| 国产精品大全| 影音先锋久久| 午夜在线电影亚洲一区| 欧美激情二区三区| 亚洲一区二区视频在线| 亚洲欧美日韩国产一区二区三区| 久久精品国产一区二区三区免费看| 欧美成人伊人久久综合网| 国产精品乱码一区二区三区| 伊人久久亚洲美女图片| 亚洲综合视频一区| 亚洲第一页中文字幕| 亚洲欧美在线观看| 欧美丝袜一区二区三区| 亚洲精品在线视频观看| 狼狼综合久久久久综合网| 亚洲午夜免费福利视频| 欧美日韩综合视频| 亚洲免费成人av| 欧美高清在线精品一区| 久久riav二区三区| 国产午夜精品麻豆| 欧美一区二区三区另类| 妖精成人www高清在线观看| 牛牛影视久久网| 亚洲国产合集| 欧美激情一区二区三区成人| 久久9热精品视频| 国产午夜精品一区理论片飘花| 午夜精品999| 亚洲午夜精品久久久久久app| 国产精品ⅴa在线观看h| 亚洲一区二区少妇| 亚洲一品av免费观看| 国产精品乱码久久久久久| 亚洲欧美另类中文字幕| 亚洲性线免费观看视频成熟| 国产精品美女久久久| 午夜日韩电影| 欧美一区二区三区视频在线| 国外精品视频| 欧美福利视频在线观看| 欧美v日韩v国产v| 亚洲精品一品区二品区三品区| 亚洲日本欧美| 国产精品人成在线观看免费| 久久国产直播| 另类亚洲自拍| 一本色道久久综合亚洲精品小说 | 久久免费视频网站| 亚洲丰满少妇videoshd| 亚洲大片在线| 国产精品激情av在线播放| 欧美在线一级va免费观看| 久久九九精品99国产精品| 亚洲国产精品99久久久久久久久| 亚洲第一在线综合网站| 欧美日韩伊人| 久久激情婷婷| 欧美高清日韩| 欧美一区午夜视频在线观看| 久久亚洲春色中文字幕| 久久激情久久| 久久午夜av| 亚洲乱码国产乱码精品精可以看 | 亚洲免费人成在线视频观看| 国产视频久久| 亚洲高清在线精品| 国产精品免费电影| 欧美成人免费全部观看天天性色| 欧美激情精品久久久久久蜜臀| 亚洲欧美卡通另类91av| 欧美成人资源网| 欧美一区三区二区在线观看| 你懂的视频一区二区| 午夜在线一区二区| 麻豆精品在线观看| 亚欧成人在线| 欧美精品免费在线观看| 久久婷婷国产综合尤物精品| 欧美日韩一级视频| 欧美成人小视频| 国产欧美韩日| 夜夜爽www精品| 亚洲日本aⅴ片在线观看香蕉| 午夜免费日韩视频| 一区二区三区国产盗摄| 麻豆成人综合网| 久久久高清一区二区三区| 欧美视频不卡| 91久久中文| 亚洲高清视频在线| 久久国产精品99国产精| 欧美亚洲视频一区二区| 欧美日韩精品三区| 亚洲国产精品久久人人爱蜜臀| 一区在线播放| 久久福利资源站| 欧美中文字幕久久| 国产美女搞久久| 亚洲婷婷综合色高清在线 | 国产精品一区二区三区免费观看| 亚洲国产另类久久精品| 亚洲二区在线视频| 狂野欧美激情性xxxx| 狂野欧美性猛交xxxx巴西| 国产伊人精品| 欧美中在线观看| 欧美在线免费观看| 国产欧美69| 欧美一区二区啪啪| 久久免费精品视频| 一区免费视频| 麻豆av一区二区三区久久| 欧美国产一区二区| 亚洲日本理论电影| 欧美精品免费在线| 一区二区日韩精品| 欧美一区二区在线视频| 国模大胆一区二区三区| 久久一综合视频| 亚洲电影在线免费观看| 日韩视频二区| 国产精品久久久久久久久久久久久久 | 国产综合在线视频| 久久综合一区二区| 欧美电影免费| 亚洲精品网址在线观看| 欧美日韩精品是欧美日韩精品| 一区二区不卡在线视频 午夜欧美不卡'| 99精品视频免费观看视频| 欧美视频官网| 亚洲一区欧美二区| 毛片一区二区| 在线亚洲一区| 国产一区二区高清视频| 免费看精品久久片| 99天天综合性| 久久久久国色av免费观看性色| 亚洲高清免费| 国产精品久久77777| 久久精品道一区二区三区| 亚洲国产人成综合网站| 欧美亚洲一区在线| 亚洲高清在线视频| 欧美三级电影大全| 久久激情婷婷| 亚洲精品免费在线| 久久久久久穴| 亚洲视频专区在线| 在线看成人片| 国产精品青草综合久久久久99 | 久热爱精品视频线路一| 99精品久久久| 欧美成人蜜桃| 欧美在线高清视频| 99综合在线| 一区二区三区在线视频免费观看| 欧美精品在线一区二区| 欧美在线观看日本一区| 亚洲精品一级| 欧美大片18| 久久天堂av综合合色| 午夜精品久久久久久久久| 亚洲美女在线国产| 亚洲国产精品女人久久久| 国产亚洲欧美日韩一区二区| 国产精品福利网| 欧美日韩亚洲一区二区三区四区 | 合欧美一区二区三区| 国产精品高潮呻吟久久av无限| 女同性一区二区三区人了人一|