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

            亚洲国产日韩欧美久久| 色成年激情久久综合| 国产亚洲精品美女久久久| 精品久久久久久99人妻| 久久久久人妻一区二区三区| 久久99国产乱子伦精品免费| 久久www免费人成看片| 热久久最新网站获取| 久久99精品久久久久久噜噜| 成人国内精品久久久久影院| 人妻无码αv中文字幕久久| 久久综合九色综合网站| 久久伊人五月丁香狠狠色| 伊色综合久久之综合久久| 久久精品国产99久久香蕉| 秋霞久久国产精品电影院| 久久精品亚洲精品国产色婷 | 成人免费网站久久久| 国内精品伊人久久久久| 老司机午夜网站国内精品久久久久久久久| A级毛片无码久久精品免费| 亚洲国产精品成人AV无码久久综合影院 | 久久国产精品99久久久久久老狼| 亚洲色欲久久久综合网| 亚洲午夜无码久久久久| 久久亚洲中文字幕精品一区四 | 色婷婷久久综合中文久久一本| 久久久久九九精品影院| 99久久人妻无码精品系列 | 久久久久久精品免费免费自慰| 久久精品国产亚洲av麻豆图片| 久久97久久97精品免视看秋霞| 国产aⅴ激情无码久久| 精品久久久久国产免费| 国产精品伊人久久伊人电影 | 久久亚洲国产欧洲精品一| 亚洲欧美精品伊人久久| 99久久婷婷国产综合亚洲| 亚洲精品午夜国产VA久久成人| 久久久久亚洲精品中文字幕| 中文字幕热久久久久久久|