#include<bits/stdc++.h>
using namespace std;
const int N=501,oo=0x3f3f3f3f;
int w[N][N],dist[N][N],t[N],n,m,q,last;
void super_floyd(int T)
{
int k=last;
for(;t[k]<=T;k++)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(dist[i][j]>dist[i][k]+dist[k][j])
{
dist[i][j]=dist[i][k]+dist[k][j];
}
}
}
}
last=k;
}
int main()
{
memset(w,0x3f,sizeof(w));
cin>>n>>m;
for(int i=0;i<n;i++) cin>>t[i];
for(int i=0;i<n;i++) w[i][i]=0;
for(int i=0;i<m;i++)
{
int u,v,d;
cin>>u>>v>>d;
w[u][v]=w[v][u]=d;
}
memcpy(dist,w,sizeof(w));
cin>>q;
while(q--)
{
int x,y,T;
cin>>x>>y>>T;
super_floyd(T);
if(t[x]>T||t[y]>T) cout<<"-1"<<endl;
else if(dist[x][y]==oo) cout<<"-1"<<endl;
else cout<<dist[x][y]<<endl;
}
return 0;
}