Codeforce 1040A Palindrome Dance (模拟)No.13

Palindrome Dance

传送
A group of n dancers rehearses a performance for the closing ceremony. The dancers are arranged in a row, they’ve studied their dancing moves and can’t change positions. For some of them, a white dancing suit is already bought, for some of them — a black one, and for the rest the suit will be bought in the future.

On the day when the suits were to be bought, the director was told that the participants of the olympiad will be happy if the colors of the suits on the scene will form a palindrome. A palindrome is a sequence that is the same when read from left to right and when read from right to left. The director liked the idea, and she wants to buy suits so that the color of the leftmost dancer’s suit is the same as the color of the rightmost dancer’s suit, the 2nd left is the same as 2nd right, and so on.

The director knows how many burls it costs to buy a white suit, and how many burls to buy a black suit. You need to find out whether it is possible to buy suits to form a palindrome, and if it’s possible, what’s the minimal cost of doing so. Remember that dancers can not change positions, and due to bureaucratic reasons it is not allowed to buy new suits for the dancers who already have suits, even if it reduces the overall spending.

Input

The first line contains three integers n, a, and b (1≤n≤20, 1≤a,b≤100) — the number of dancers, the cost of a white suit, and the cost of a black suit.

The next line contains n numbers ci, i-th of which denotes the color of the suit of the i-th dancer. Number 0 denotes the white color, 1 — the black color, and 2 denotes that a suit for this dancer is still to be bought.

Output

If it is not possible to form a palindrome without swapping dancers and buying new suits for those who have one, then output -1. Otherwise, output the minimal price to get the desired visual effect.

Examples

input

5 100 1
0 1 2 1 2

output

101

input

3 10 12
1 2 0

output

-1

input

3 12 1
0 1 0

output

0

Note

In the first sample, the cheapest way to obtain palindromic colors is to buy a black suit for the third from left dancer and a white suit for the rightmost dancer.

In the second sample, the leftmost dancer’s suit already differs from the rightmost dancer’s suit so there is no way to obtain the desired coloring.

In the third sample, all suits are already bought and their colors form a palindrome.


题目大意:

合唱队教练想让大家的西装颜色形成回文,问你最少需要多少钱?
ps:已经有西装的人不能换颜色

做法:

两个指针模拟一遍(因为偷懒用了两个数组),对应的两人都没衣服穿就穿最便宜的,衣服颜色不同就输出-1

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include<iostream>
#include<cstdio>
using namespace std;
int n,a[100010],b[100010];
int cw,cb;
long long ans;
void debug(){
for(int i=1;i<=n;i++){
cout<<a[i]<<" ";
}
cout<<endl;
for(int i=1;i<=n;i++){
cout<<b[i]<<" ";
}
cout<<endl;
}
int main(){
cin>>n>>cw>>cb;
for(int i=1;i<=n;i++){
cin>>a[i];
b[n-i+1]=a[i];
}
for(int i=1;i<=(n+1)/2;i++){
if(a[i]==b[i]&&a[i]!=2) continue;
else{
if(a[i]!=2&&b[i]!=2){
cout<<"-1"<<endl;
return 0;
}
if(a[i]==2&&b[i]==0){
ans+=cw;
}
if(a[i]==0&&b[i]==2){
ans+=cw;
}
if(a[i]==2&&b[i]==1){
ans+=cb;
}
if(a[i]==1&&b[i]==2){
ans+=cb;
}
if(a[i]==2&&b[i]==2){
ans+=min(cw,cb);
if(n%2==0)
ans+=min(cw,cb);
else if(i!=(n+1)/2){
ans+=min(cw,cb);
}
}
}
}
cout<<ans<<endl;
return 0;
}

Powered by Hexo and Hexo-theme-hiker

Copyright © 2013 - 2018 Gilgamesh All Rights Reserved.

UV : | PV :