欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

PKU 1549/TJU 1927/NK 1420 Bright Bracelet

系統(tǒng) 1724 0

Time Limit: 3000 ms ?? Memory Limit: 10000 kB?? ?
Total Submit : 2 ? (1 user) ??? Accepted Submit : 2 ? (1 user) ??? Page View : 1582 ?

??? 本題其實(shí)并不難,就是記憶搜索,但是好多人都沒(méi)做。最難的估計(jì)就是狀態(tài)的存儲(chǔ),一開(kāi)始的時(shí)候我用的是三維數(shù)組存儲(chǔ),雖然在TJU和NK上都過(guò)了,但是在北大上確實(shí)WRONG,后來(lái)我又重新開(kāi)了一遍發(fā)現(xiàn)確實(shí)存在錯(cuò)誤,后來(lái)將數(shù)組開(kāi)到四維才在北大上順利通過(guò)。因?yàn)楸绢}我竟然成了NK上第一個(gè)提交此題并A的人。值得留念!

代碼:

?

      
1 #include < stdio.h >
2 #include < string .h >
3 ? char end,str[ 15 ][ 10 ];
4 int n,dp[ 2050 ][ 10 ][ 10 ][ 10 ],mark[ 15 ],a[ 10 ];
5 int test( int sum, char u, char f, int c)
6 {
7 int term,i,j,min = 0xfffffff ;
8 if (dp[sum][u - ' A ' + 1 ][f - ' A ' + 1 ][end - ' A ' + 1 ] != 0 )
9 return dp[sum][u - ' A ' + 1 ][f - ' A ' + 1 ][end - ' A ' + 1 ];
10 if (c == n)
11 {
12 if (f == end)
13 return a[(f - ' A ' ) + 1 ];
14 return - 1 ;
15 }
16 for (i = 2 ;i <= n;i ++ )
17 {
18 if (mark[i])
19 continue ;
20 mark[i] = 1 ;
21 for (j = 0 ;j < 8 ;j ++ )
22 {
23 if (f == str[i][j])
24 {
25 term = test(sum - ( 1 << (i - 1 )),f,str[i][(j + 4 ) % 8 ],c + 1 );
26 dp[sum - ( 1 << (i - 1 ))][f - ' A ' + 1 ][str[i][(j + 4 ) % 8 ] - ' A ' + 1 ][end - ' A ' + 1 ] = term;
27 if (term !=- 1 )
28 {
29 if (term + a[f - ' A ' + 1 ] < min)
30 min = term + a[f - ' A ' + 1 ];
31 }
32 }
33 }
34 mark[i] = 0 ;
35 }
36 if (min == 0xfffffff )
37 return - 1 ;
38 return min;
39 }
40
41 int main()
42 {
43 int i,min,term,sum;
44 while (scanf( " %d " , & n) != EOF)
45 {
46 if (n == 0 )
47 break ;
48 min = 0xfffffff ;
49 memset(mark, 0 , sizeof (mark));
50 memset(dp, 0 , sizeof (dp));
51 for (i = 1 ;i <= 8 ;i ++ )
52 {
53 scanf( " %d " , & a[i]);
54 }
55 for (i = 1 ;i <= n;i ++ )
56 {
57 scanf( " %s " ,str[i]);
58 }
59 mark[ 1 ] = 1 ;
60 sum = ( 1 << n) - 1 ;
61 for (i = 0 ;i < 4 ;i ++ )
62 {
63 end = str[ 1 ][(i + 4 ) % 8 ];
64 term = test(sum - 1 ,str[ 1 ][(i + 4 ) % 8 ],str[ 1 ][i], 1 );
65 dp[sum - 1 ][end - ' A ' + 1 ][str[ 1 ][i] - ' A ' + 1 ][end - ' A ' + 1 ] = term;
66 if (term !=- 1 )
67 {
68 if (term < min)
69 min = term;
70 }
71 }
72 if (min != 0xfffffff )
73 {
74 printf( " %d\n " ,min);
75 }
76 else
77 printf( " impossible\n " );
78 }
79 return 0 ;
80 }
81
82
83

?

PKU 1549/TJU 1927/NK 1420 Bright Bracelet


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 日日摸夜夜添夜夜添破第一 | 国产精品成在线观看 | 久久一级 | 亚洲精品久久久 | 激情a| 久久精品国产999大香线焦 | 久久99国产亚洲精品观看 | 免费成人午夜视频 | 国产成人高清视频免费播放 | 毛片在线视频观看 | 精品国产第一国产综合精品 | 久久久久国产精品免费免费搜索 | 亚洲国产综合精品中文第一区 | 污视频在线观看网站 | 99精品视频在线在线视频观看 | a级毛片高清免费视频 | 日本爽爽爽爽爽爽免费 | 亚洲精品欧美一区二区三区 | 国产区视频在线观看 | 午夜性电影 | 国产精品婷婷久久久久 | 亚洲精品电影在线观看 | 成人免播放器午夜视频 | 窝窝午夜精品一区二区 | 色屁屁www影院免费观看软件 | 激情 婷婷| 午夜精品久久久久久久99热浪潮 | 亚洲人成在线播放 | 丝袜美腿中文字幕 | 且试天下修久容 | 亚洲区激情区图片小说区 | 偷拍在线观看视频在线观看地址 | 成人三级视频 | 色婷婷社区| 成人一区二区三区 | 国产免费麻豆 | 亚洲国产欧美在线人网站 | 精品欧美一区二区精品久久久 | 成人免费一区二区三区视频网站 | 婷婷六月在线 | 一区二区三区日韩精品 |