#include <cstdio>#include <cstdlib>#include <cstring>#include <algorithm>#include <iostream>#include <vector>#include <set>using namespace std;const int N = 210 ;int n , k ;double a , b ;int magic ;vector<int> v ;set<int> s ;double dp[N][N] ;double calc(int l,int r){ if (l>r) return 0 ; if (dp[l][r] != -1) return dp[l][r] ; double sx = 0 ; for (int i = l ; i <= r ; i++){ sx += ((v[i]==magic)?1.0:0.0) * a ; sx += calc(l,i-1) * b ; sx += calc(i+1,r) * (1.0-a-b) ; } dp[l][r] = sx / (r-l+1) ; return dp[l][r] ;}int main(){ while (scanf("%d",&n)==1 && n>=0){ v.clear(); s.clear(); for (int i = 0 ; i < n ; i++){ int t ; scanf("%d",&t); v.push_back(t) ; s.insert(t) ; } for (int i = 0 ; i < n ; i++) for (int j = 0 ; j < n ; j++) dp[i][j] = -1 ; scanf("%d%lf%lf",&k,&a,&b) ; set<int>::iterator it ; int ak = 0 ; magic = -1 ; for (it = s.begin() ; it != s.end() ; it++) { ak++ ; if (ak==k) { magic = (*it) ; break ; } } if (magic==-1){ printf("0.000n"); continue ; } printf("%.3fn",calc(0,n-1)); } return 0 ;}


