//Accepted 4792 KB 281 ms
//区间dp
//dp[i][j][k] i到j整段区间在第k个出去时的最小花费
//考虑区间中的第一个元素i,有一下两种情况:
//(1)i在第k个出去,则i+1到j在第k+1个出去即dp[i+1][j][k+1]
//(2)i不在第k个出去,则i后必有一段在第k个出去,假设这段为i+1到m
//则有dp[i+1][m][k]+a[i]*(k+m-i)+dp[m+1][j][k+m-i+1]
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
;
;
int dp[imax_n][imax_n][imax_n];
int a[imax_n];
int n;
int min(int a,int b)
{
return a<b?a:b;
}
void Dp()
{
memset(dp,,sizeof(dp));
;i<=n;i++)
{
;k<=n;k++)
{
dp[i][i][k]=(k-)*a[i];
}
}
;i<n;i++)
{
;k<=n;k++)
{
dp[i][i+][k]=min((k-)*a[i]+k*a[i+],k*a[i]+(k-)*a[i+]);
}
}
;l<=n;l++)
{
;i<=n;i++)
{
;
if (j>n) break;
;k<=n;k++)
{
dp[i][j][k]=inf;
dp[i][j][k]=min(dp[i][j][k],dp[i+][j][k+]+(k-)*a[i]);
;m<=j;m++)
{
dp[i][j][k]=min(dp[i][j][k],dp[i+][m][k]+a[i]*(k+m-i-)+dp[m+][j][k++m-i]);
}
}
}
}
}
int main()
{
int T;
scanf("%d",&T);
;t<=T;t++)
{
scanf("%d",&n);
;i<=n;i++)
scanf("%d",&a[i]);
Dp();
printf(][n][]);
}
;
}