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
?
更多文章、技術(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ì)您有幫助就好】元
