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

a tutorial on computer science

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  21 隨筆 :: 0 文章 :: 17 評論 :: 0 Trackbacks
        題目的意思很簡單,給出N個(gè)正整數(shù),求最大的,長度大于K的某一段的平均值。好吧,這句聽起來有點(diǎn)拗口。數(shù)學(xué)表達(dá)式就是 Max(ave(i,j))   (j-i>=K)。
       這題是去年百度之星第二場比賽的一道題,煞費(fèi)苦心不會(huì)做,那時(shí)候看了論文也不會(huì)做。過了快一年了,今天終于把它A掉了。。。
      
       首先,ave(i,j)可以變形為一個(gè)式子, ave(i,j) = (sum[j] - sum[i-1]  ) / (j - i + 1) 。
       這個(gè)式子要表達(dá)什么意思呢?表示j點(diǎn)到i點(diǎn)得斜率!如此神奇的想法。。。
      變成斜率之后,問題遠(yuǎn)遠(yuǎn)沒有得到解決。問題變成了給出N個(gè)點(diǎn)的坐標(biāo),求這N個(gè)點(diǎn)任意連線的最大斜率。最普通的辦法:從前到后枚舉N個(gè)點(diǎn),再枚舉前0到i-k個(gè)點(diǎn),比較的出最大斜率。但是通過作圖我們可以得出一個(gè)結(jié)論,對于三個(gè)點(diǎn),a,b,c,如果ca的斜率比cb的大,那么以后任意一個(gè)點(diǎn),到點(diǎn)b的斜率都不可能比到a和c的大。所以這時(shí)候要舍棄掉b點(diǎn)。所以在維護(hù)前面0,i-K個(gè)點(diǎn)得時(shí)候,如果出現(xiàn)了上述提到的情況,則刪除點(diǎn)b,好了,這樣復(fù)雜度最壞情況下還是N^2。我們繼續(xù)想,當(dāng)出現(xiàn)一個(gè)新的點(diǎn)得時(shí)候,真的要枚舉前面所有的點(diǎn)嗎?我們只要找到維護(hù)的點(diǎn)到當(dāng)前點(diǎn)得切線就好了,這個(gè)可以用二分查找找出來,比較麻煩。最后一步神優(yōu)化:當(dāng)當(dāng)前維護(hù)的點(diǎn)得前面的點(diǎn)不是最大斜率的時(shí)候,以后的點(diǎn)也不可能是最大斜率。這個(gè)自己證明去吧~
     這個(gè)題煞費(fèi)苦心的想了一天,明白怎么回事了,發(fā)現(xiàn)結(jié)論很簡單。但是交到hdoj上的時(shí)候,TLE了。沒耐心看了discuss,原來是scanf要自己寫。不想寫,百度代碼,發(fā)現(xiàn)有個(gè)神人寫了五十行的代碼,未自己寫輸入,交,A之。原來是自己的代碼太冗余了。于是便仿照他的寫法,發(fā)現(xiàn)問題很簡單,一切很明了~A之。代碼如下:
//by bigrabbit

#include 
<stdio.h>

typedef 
struct
{
  
int x,y;
}
node;
node queue[
100010],tmp;
int head,tail;

double res;

int N,K,sum[100010];

double max(double a,double b)
{
    
if(a > b)
      
return a;
    
return b;
}


long long xmul(node a,node b,node c)
{
   
return (long long)(c.y-a.y)*(b.x-a.x) - (long long)(b.y - a.y)*(c.x - a.x) ;
}


int main()
{
    
int i;
   
while(scanf("%d%d",&N,&K)!=EOF)   
   
{
     sum[
0= 0;
     
for(i=1;i<=N;i++)
     
{
        scanf(
"%d",&sum[i]);
        sum[i] 
+= sum[i-1];
     }

  
     head 
= tail = 0;
     res 
= 0.0;
    
     
for(i=K;i<=N;i++)
     
{
        tmp.x 
= i-K;
        tmp.y 
= sum[i-K];
        
while(head - tail >= 2 && xmul(queue[head-2],queue[head-1],tmp) <= 0 ) 
         head
--;
        queue[head
++= tmp;
        
         node now;
        now.x 
= i;now.y = sum[i];
        
while(head - tail >= 2 && xmul(queue[tail],queue[tail+1],now) >= 0 )  
          tail
++;
   
        res 
= max(res,(double)(sum[i] - queue[tail].y)/(double)(i - queue[tail].x));
     }

    printf(
"%.2f\n",res);
   }

   
return 0;
}

posted on 2012-03-08 16:27 bigrabbit 閱讀(1021) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美午夜女人视频在线| 欧美色播在线播放| 久久字幕精品一区| 乱码第一页成人| 男同欧美伦乱| 欧美另类女人| 国产精品成人播放| 国产精品视频一二三| 久久久精品999| 久久人人精品| 欧美激情女人20p| 欧美视频一区在线| 国产精品一区在线播放| 国内精品亚洲| 亚洲黄色免费| 一区二区欧美日韩| 香蕉av777xxx色综合一区| 久久成人人人人精品欧| 久久综合九色综合久99| 欧美福利视频一区| 亚洲美女免费精品视频在线观看| 免费观看欧美在线视频的网站| 香蕉久久久久久久av网站| 久久精品亚洲国产奇米99| 另类春色校园亚洲| 久久看片网站| 亚洲国产美女| 亚洲二区在线视频| 日韩一级精品视频在线观看| 亚洲国产精品久久久久婷婷884| 猫咪成人在线观看| 日韩视频中文字幕| 欧美一区综合| 欧美久久婷婷综合色| 国产欧美91| 亚洲欧洲日夜超级视频| 亚洲在线视频观看| 亚洲小说欧美另类社区| 久久gogo国模啪啪人体图| 欧美激情亚洲视频| 亚洲一区二区影院| 欧美福利一区| 好男人免费精品视频| 一区二区三区高清视频在线观看| 夜夜夜久久久| 久久嫩草精品久久久精品一| 亚洲精品乱码久久久久久蜜桃91| 亚洲裸体俱乐部裸体舞表演av| 亚洲人成在线免费观看| 欧美一区二区久久久| 欧美理论电影在线观看| 国产综合18久久久久久| 夜夜夜精品看看| 欧美成年人视频网站| 亚洲国产精品第一区二区| 亚洲精品孕妇| 一区二区三区欧美在线| 久久婷婷影院| 国产亚洲欧美一区二区三区| 狠狠干综合网| 亚洲美女在线视频| 开心色5月久久精品| 亚洲视频专区在线| 久久国产黑丝| 国产精品美女久久久| 亚洲肉体裸体xxxx137| 亚洲视频一区二区在线观看| 欧美电影打屁股sp| 性欧美办公室18xxxxhd| 国产精品mv在线观看| 亚洲精品在线看| 卡一卡二国产精品| 亚洲国产精品成人综合色在线婷婷| 久久国产主播精品| 中文久久精品| 欧美一区二区三区在线免费观看| 麻豆视频一区二区| 国内精品久久久久久久影视麻豆 | 性亚洲最疯狂xxxx高清| 欧美一进一出视频| 亚洲视频日本| 欧美午夜电影一区| 这里只有视频精品| 亚洲精品综合精品自拍| 欧美77777| 国产精品综合久久久| 亚洲影音一区| 一本大道av伊人久久综合| 欧美女激情福利| 亚洲美女免费视频| 亚洲高清三级视频| 欧美成人激情视频| 亚洲精品一区中文| 久久免费高清| 久久精品国产亚洲aⅴ| 激情欧美日韩| 另类av导航| 蜜臀久久99精品久久久久久9| 国产精品免费福利| 欧美影院成年免费版| 亚洲欧美在线播放| 韩国av一区二区三区| 亚洲主播在线播放| 亚洲一区二区三区精品在线观看 | 亚洲私人黄色宅男| 99精品99久久久久久宅男| 欧美三区不卡| 午夜精品亚洲| 欧美一区二区播放| 亚洲第一区在线| 亚洲夫妻自拍| 欧美日韩一区自拍| 欧美在线亚洲一区| 久久精品三级| 亚洲人成在线播放| 亚洲精品国精品久久99热| 欧美日韩午夜视频在线观看| 亚洲自啪免费| 久久成人国产精品| 亚洲精品国精品久久99热一| 99精品视频免费| 国产麻豆精品视频| 欧美成人精品三级在线观看| 欧美韩国一区| 午夜精品免费| 久久漫画官网| 中文av字幕一区| 欧美影院精品一区| 91久久午夜| 亚洲婷婷在线| 在线播放国产一区中文字幕剧情欧美| 久久精品成人| 欧美高清视频一区二区| 亚洲女人天堂av| 久久国产欧美| 一本一本大道香蕉久在线精品| 亚洲国产精品99久久久久久久久| 蜜臀99久久精品久久久久久软件| 韩国视频理论视频久久| 亚洲第一页中文字幕| 国产精品久在线观看| 美国十次成人| 久久综合狠狠综合久久综青草| 在线观看不卡| 亚洲深夜福利| 亚洲国产精品激情在线观看| 欧美国产日产韩国视频| 欧美无乱码久久久免费午夜一区| 中文av一区特黄| 久久久精品国产一区二区三区| 亚洲第一区中文99精品| 日韩写真在线| 在线观看一区欧美| 亚洲一区二区在线观看视频| 亚洲国产日日夜夜| 午夜久久久久久| 亚洲视频专区在线| 美国十次成人| 亚洲深夜福利| 开心色5月久久精品| 99国内精品| 久久久国产一区二区| 亚洲在线成人| 欧美激情精品| 欧美成人精品福利| 国产一区二区精品在线观看| 亚洲美女在线国产| 91久久国产综合久久91精品网站| 亚洲精品四区| 亚洲国产精品成人综合| 亚洲一区美女视频在线观看免费| 国内偷自视频区视频综合| 一区二区免费看| 亚洲精品视频免费| 另类欧美日韩国产在线| 久久精品亚洲一区二区| 国产精品国产福利国产秒拍| 亚洲国产欧美日韩精品| 尤物九九久久国产精品的特点 | 蜜桃精品久久久久久久免费影院| 麻豆成人综合网| 老司机免费视频久久| 欧美激情片在线观看| 欧美大胆成人| 尤物99国产成人精品视频| 欧美一区二区私人影院日本| 亚洲欧美国产77777| 欧美日韩午夜在线视频| 亚洲精品资源美女情侣酒店| 亚洲欧洲日本国产| 美女网站久久| 亚洲成人资源网| 欧美va天堂va视频va在线| 国产欧美日韩麻豆91| 亚洲一区二区在线看| 午夜精品在线视频| 国产精品视频导航| 亚洲综合日韩在线| 欧美在线视频免费播放| 国产日韩精品视频一区|