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

A Za, A Za, Fighting...

堅信:勤能補拙

PKU 1179 Polygon

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=1179

思路:
這題輸在了對原題目的理解和分析上,沒能成功地走出第一步:
                                                      將原題解析成對于表達式的求解
把缺了一條邊的多邊形展開成直線就是一個表達式
注意:為了求乘法,必須同時保存最大值和最小值

f[i][j]記錄表達式中從頂點i到頂點j這段子表達式的值

動態規劃的思想類似于矩陣連乘

參考:
http://hi.baidu.com/xiehuixb/blog/item/575ec81e221466c1a786699e.html

代碼:
 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 #include<string.h>
 4 #define MAX_LEN 51
 5 #define INF 9223372036854775807LL
 6 #define maximal(a, b) ((a)>(b) ? (a) : (b))
 7 #define minimal(a, b) ((a)<(b) ? (a) : (b))
 8 char operand[MAX_LEN][2];
 9 int operators[MAX_LEN];
10 int n, ans_len, ans[MAX_LEN];
11 long long int rt, max[MAX_LEN][MAX_LEN], min[MAX_LEN][MAX_LEN];
12 
13 /*
14  * when it comes to: '+'
15  * max[i][j] = maximal(max[i][k] + max[k+1][j])
16  * min[i][j] = minimal(min[i][k] + min[k+1][j])
17  *
18  * when it comes to: '*'
19  * max[i][j] = maximal(max[i][k]*max[k+1][j], max[i][k]*min[k+1][j], min[i][k]*max[k+1][j], min[i][k]*min[k+1][j])
20  * min[i][j] = minimal(max[i][k]*max[k+1][j], max[i][k]*min[k+1][j], min[i][k]*max[k+1][j], min[i][k]*min[k+1][j])
21  *
22  * i<=k<j
23  */
24 void
25 solve(char *opd, int *ops, int del_edge)
26 {
27     int i, j, k, len;
28     for(i=1; i<=n; i++)
29         max[i][i] = min[i][i] = ops[i];
30     for(len=2; len<=n; len++) {
31         for(i=1; i<=n-len+1; i++) {
32             j = i+len-1;
33             max[i][j] = -INF;
34             min[i][j] = INF;
35             for(k=i; k<j; k++) {
36                 if(opd[k] == 't') {
37                     max[i][j] = maximal(max[i][j], max[i][k]+max[k+1][j]);
38                     min[i][j] = minimal(min[i][j], min[i][k]+min[k+1][j]);
39                 } else { /* opd[k] == 'x' */
40                     max[i][j] = maximal(max[i][j], max[i][k]*max[k+1][j]);
41                     max[i][j] = maximal(max[i][j], max[i][k]*min[k+1][j]);
42                     max[i][j] = maximal(max[i][j], min[i][k]*max[k+1][j]);
43                     max[i][j] = maximal(max[i][j], min[i][k]*min[k+1][j]);
44 
45                     min[i][j] = minimal(min[i][j], max[i][k]*max[k+1][j]);
46                     min[i][j] = minimal(min[i][j], max[i][k]*min[k+1][j]);
47                     min[i][j] = minimal(min[i][j], min[i][k]*max[k+1][j]);
48                     min[i][j] = minimal(min[i][j], min[i][k]*min[k+1][j]);
49                 }
50             }
51         }
52     }
53     if(max[1][n] >= rt) {
54         if(max[1][n] == rt)
55             ans[ans_len++= del_edge;
56         else {
57             rt = max[1][n];
58             ans_len = 0;
59             ans[ans_len++= del_edge;
60         }
61     }
62 }
63 
64 int
65 main(int argc, char **argv)
66 {
67     int i, j, k;
68     char tmpopd[MAX_LEN];
69     int tmpops[MAX_LEN];
70     while(scanf("%d"&n) != EOF) {
71         for(i=1; i<=n; i++)
72             scanf("%s%d", operand[i], operators+i);
73         rt = -INF;
74         ans_len = 0;
75         for(i=1; i<=n; i++) {
76             for(j=i%n+1, k=1; j!=i; j=j%n+1, k++)
77                 tmpopd[k] = operand[j][0];
78             tmpopd[k] = '\0';
79             tmpops[1= operators[i];
80             for(j=i%n+1, k=2; j!=i; j=j%n+1, k++)
81                 tmpops[k] = operators[j];
82             solve(tmpopd, tmpops, i);
83         }
84         printf("%lld\n", rt);
85         for(i=0; i<ans_len; i++)
86             printf("%d ", ans[i]);
87         printf("\n");
88     }
89 }

posted on 2010-08-17 13:51 simplyzhao 閱讀(159) 評論(0)  編輯 收藏 引用 所屬分類: C_動態規劃

導航

<2010年7月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美激情综合五月色丁香| 免费高清在线视频一区·| 国产欧美日韩亚洲一区二区三区| 欧美精品在线视频| 欧美日韩中文另类| 国产精品美女久久福利网站| 国产精品成人在线观看| 国产区精品视频| 一区二区三区在线免费观看| 一区在线视频观看| 亚洲精品一区二区三区婷婷月| 亚洲国产一区二区a毛片| 日韩网站在线| 欧美一区二区视频网站| 蜜臀久久99精品久久久久久9| 亚洲成人在线免费| 毛片一区二区三区| 亚洲高清二区| 亚洲永久在线观看| 免费看成人av| 国产精品亚洲综合| 蜜桃av一区二区在线观看| 久久精品论坛| 久久精品夜色噜噜亚洲a∨| 欧美成人精品1314www| 欧美日韩一卡| 揄拍成人国产精品视频| 亚洲视频每日更新| 欧美黄色一区二区| 午夜一级在线看亚洲| 欧美人与性动交a欧美精品| 国产主播在线一区| 午夜在线精品偷拍| 亚洲精品久久久久久一区二区| 小处雏高清一区二区三区| 欧美大片在线影院| 在线高清一区| 久久精品一区| 亚洲一区二区毛片| 欧美久久久久久久久| 在线观看精品| 久久精品女人天堂| 亚洲欧美日韩国产一区| 欧美日韩在线播放| 一本色道精品久久一区二区三区| 麻豆精品视频在线| 欧美一区二区成人6969| 国产精品国产三级国产普通话三级| 亚洲片区在线| 亚洲国产va精品久久久不卡综合| 久久久91精品国产| 国产在线精品二区| 久久久久久夜| 久久精品30| 精品不卡一区| 麻豆成人综合网| 久久激情视频久久| 激情婷婷亚洲| 欧美+亚洲+精品+三区| 久久久久久有精品国产| 伊人久久男人天堂| 女生裸体视频一区二区三区| 久久精品av麻豆的观看方式| 国产日韩欧美| 久久午夜视频| 久久夜精品va视频免费观看| 黄色日韩网站视频| 欧美成人激情视频| 欧美激情精品久久久久久| 日韩一二三在线视频播| 日韩亚洲在线| 国产欧美二区| 欧美超级免费视 在线| 女仆av观看一区| 夜夜精品视频| 亚洲欧美日韩精品一区二区 | 亚洲免费中文| 国产女人精品视频| 麻豆免费精品视频| 亚洲午夜久久久久久久久电影院| 国产精品99免费看| 欧美在现视频| 久久综合伊人77777蜜臀| 亚洲日本视频| 亚洲午夜视频在线| 国内偷自视频区视频综合| 嫩草成人www欧美| 欧美区视频在线观看| 欧美一区二区三区四区视频| 久久成人免费电影| 亚洲美女中文字幕| 午夜精品亚洲| 亚洲日本在线视频观看| 亚洲一区日本| 亚洲国产天堂久久综合| 一区二区三区四区精品| 黄色日韩网站视频| 一区二区欧美日韩视频| 激情六月婷婷综合| 国产精品99久久久久久宅男| 激情综合久久| 一区二区三区免费观看| 1000部精品久久久久久久久| 99精品久久免费看蜜臀剧情介绍| 狠狠色伊人亚洲综合网站色| 亚洲精品综合久久中文字幕| 国产一区高清视频| 一本大道av伊人久久综合| 亚洲激情二区| 欧美一区二区三区精品电影| 日韩亚洲欧美在线观看| 久久精品国产999大香线蕉| 亚洲一本大道在线| 欧美国产专区| 欧美激情精品久久久久久久变态| 国产精品久久久久久久浪潮网站| 亚洲电影观看| 亚洲国产日韩欧美在线图片| 香蕉成人久久| 亚洲综合丁香| 欧美日韩在线亚洲一区蜜芽 | 欧美国产日韩精品| 国产综合视频| 欧美一级视频一区二区| 亚洲系列中文字幕| 欧美日韩高清一区| 亚洲人成网站精品片在线观看| 一区二区三区亚洲| 久久精品亚洲精品国产欧美kt∨| 午夜欧美大尺度福利影院在线看| 欧美日韩精品一区二区| 亚洲破处大片| 亚洲精品一二三| 欧美精品免费看| 亚洲人久久久| 亚洲精品你懂的| 欧美激情五月| 亚洲日本免费| 亚洲深夜福利| 国产精品久久中文| 亚洲一区二区三区免费在线观看| 亚洲午夜性刺激影院| 久久久亚洲欧洲日产国码αv| 久久天天综合| 国产一区二区日韩精品| 午夜精品久久久久影视| 亚洲影院在线| 国产麻豆精品theporn| 性欧美精品高清| 免费在线视频一区| 日韩视频精品在线| 欧美日韩精品欧美日韩精品一 | 欧美在线三区| 欧美成人精品在线| 一本一本大道香蕉久在线精品| 欧美日韩亚洲系列| 亚洲综合导航| 久久综合伊人77777蜜臀| 在线国产欧美| 欧美va亚洲va国产综合| 亚洲精品久久久久久一区二区| 一区二区三区偷拍| 国产精品日韩欧美一区| 欧美在线免费看| 亚洲国产视频一区二区| 亚洲小说欧美另类婷婷| 国产亚洲精品久久久久婷婷瑜伽| 麻豆国产va免费精品高清在线| 日韩亚洲欧美综合| 久久经典综合| 亚洲国产综合91精品麻豆| 欧美日韩视频免费播放| 亚洲欧美一区二区原创| 亚洲国产精品一区在线观看不卡 | 欧美99在线视频观看| 夜夜狂射影院欧美极品| 国产一区二区三区免费不卡| 欧美高清视频www夜色资源网| 日韩视频中午一区| 美女脱光内衣内裤视频久久网站| 制服丝袜激情欧洲亚洲| 影音先锋亚洲电影| 国产精品私人影院| 欧美欧美全黄| 久久久亚洲人| 亚洲专区一区| 亚洲精品日韩激情在线电影| 久久蜜桃资源一区二区老牛| 一区二区三区**美女毛片| 一区二区三区在线观看国产| 国产精品久久精品日日| 欧美高清在线视频| 久久婷婷久久| 久久精品国产视频| 亚洲免费人成在线视频观看| 亚洲人成久久| 亚洲成人在线网| 美女999久久久精品视频| 性色av一区二区三区在线观看| 99在线热播精品免费|