• <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>

            ArcTan

            dfs
            隨筆 - 16, 文章 - 117, 評論 - 6, 引用 - 0
            數(shù)據(jù)加載中……

            poj 2559 poj 2082(單調(diào)棧)

            昨天ACdream群里在討論單調(diào)棧,今天就遇到無數(shù)WA,現(xiàn)在也沒有沒有搞明白單調(diào)棧的原理,更沒有搞明白我的DP 或者 貪心,怎么不對。
            單調(diào)棧是個好東西,容我去看看啊!
            poj 2559
            總結(jié):long long類型,要和int區(qū)分開來,輸出格式用"%I64d"。
                    數(shù)據(jù)結(jié)構(gòu)該看看了。
                    自己多分析分析。
            寫完一次就AC了,之前的貪心一直都WA呢。囧……
            #include<stdio.h>
            #include
            <string.h>
            #include
            <math.h>
            int n,pos[100005];
            long long stack[100005];
            int main()
            {
                
            int i,top;
                
            long long a,ans;
                
            while (scanf("%d",&n)==1&&n)
                {
                    top
            =0;ans=0;
                    stack[top]
            =0;pos[top]=0;
                    
            for (i=1 ;i<=n ;i++ )
                    {
                        scanf(
            "%I64d",&a);
                        
            while (top>0&&a<=stack[top])
                        {
                            
            if (ans<(long long)(i-1-pos[top-1])*stack[top])  
                                ans
            =(long long)(i-1-pos[top-1])*stack[top];
                            top
            --;
                        }
                        top
            ++;
                        stack[top]
            =a;
                        pos[top]
            =i;
                    }
                    
            while (top>0)
                    {
                        
            if (ans<(long long)(n-pos[top-1])*stack[top])
                            ans
            =(long long)(n-pos[top-1])*stack[top];
                        top
            --;
                    }
                    printf(
            "%I64d\n",ans);
                }
                
            return 0;
            }

            poj 2082
                 這個題目比較坑爹,簡單的問題讓他給敘述的深奧無比!NP!!!!數(shù)學(xué)理解能力當(dāng)然重要啊!
              搞清題意后,想到的就是DP了,感覺有個四邊形不等式在里面可以用。。。貪心法應(yīng)該也是正確的啊,不過一直WA,也不知道怎么回事。該好好研究研究單調(diào)棧,單調(diào)隊列了。。。。嗚嗚嗚匆
              WA了無數(shù)次,單調(diào)棧一次AC!
            #include<stdio.h>
            #include
            <string.h>
            #include
            <math.h>
            int n;
            long long stack[50005],pos[50005],sum;
            long long ans,w,h;
            int main()
            {
                
            int i,top;
                
            while (scanf("%d",&n)==1&&n!=-1)
                {
                    sum
            =0;top=0;ans=0;
                    
            for (i=1;i<=n ;i++ )
                    {
                        scanf(
            "%I64d%I64d",&w,&h);
                        
                        
            while (top>0&&h<=stack[top])
                        {
                            
            if (ans<(sum-pos[top-1])*stack[top])
                                ans
            =(sum-pos[top-1])*stack[top];
                            top
            --;
                        }
                        sum
            +=w;
                        top
            ++;
                        stack[top]
            =h;
                        pos[top]
            =sum;
                    }
                    
            while (top>0)
                    {
                        
            if (ans<(sum-pos[top-1])*stack[top])
                            ans
            =(sum-pos[top-1])*stack[top];
                        top
            --;
                    }
                    printf(
            "%I64d\n",ans);
                }
                
            return 0;
            }

            額,要學(xué)的東西還很多啊。

            posted on 2012-04-24 14:53 wangs 閱讀(616) 評論(0)  編輯 收藏 引用 所屬分類: ACM-數(shù)據(jù)結(jié)構(gòu)

            伊人久久综合热线大杳蕉下载| 人妻少妇久久中文字幕| 国产亚洲精午夜久久久久久| 国产精品丝袜久久久久久不卡 | 色婷婷综合久久久久中文 | 一级女性全黄久久生活片免费 | 精品国产一区二区三区久久蜜臀| 日韩欧美亚洲综合久久影院Ds| 亚洲欧美伊人久久综合一区二区| 成人国内精品久久久久影院VR| 久久天天躁狠狠躁夜夜躁2014| 91精品婷婷国产综合久久| 亚洲?V乱码久久精品蜜桃 | 日韩亚洲欧美久久久www综合网 | 日韩精品久久久久久| 亚洲午夜久久久影院| 午夜精品久久久久久影视777| 97久久天天综合色天天综合色hd| 久久久久一级精品亚洲国产成人综合AV区 | 久久精品国产99久久久| 一级做a爰片久久毛片免费陪| 天天综合久久久网| 国产成人无码久久久精品一| 2021国内精品久久久久久影院| AA级片免费看视频久久| 青青青青久久精品国产h| 久久99精品久久久久久hb无码| 伊人久久大香线蕉av不变影院| 香蕉久久AⅤ一区二区三区| 97久久精品人人澡人人爽| 999久久久免费精品国产| 国产精品一久久香蕉产线看| 色综合久久久久无码专区| 久久99精品久久久久子伦| 久久久久免费看成人影片| 久久99精品国产99久久6男男| 久久久噜噜噜久久中文福利| 久久精品国产亚洲AV嫖农村妇女| 亚洲狠狠婷婷综合久久蜜芽| 国产∨亚洲V天堂无码久久久| 亚洲精品tv久久久久久久久|