import sys input = sys.stdin.readline N,M,K=map(int,input().split()) S=list(map(int,input().split())) # グラフの最短距離を全て求める(ワーシャル–フロイド法) Distance=[[float("inf") for i in range(N+1)] for j in range(N+1)] for i in range(N+1): Distance[i][i]=0 for i in range(M): i,j,t=map(int,input().split()) Distance[i][j]=Distance[j][i]=t # 分かっている距離を書き込んでおく. for k in range(1,N+1): # k個までの町を使ってのDisが知れているときに for i in range(1,N+1): # 町iと for j in range(i,N+1): # 町jとの最短距離は、 length=Distance[i][k]+Distance[j][k] if Distance[i][j]>length: Distance[i][j]=Distance[j][i]=length LANS=[] Q=int(input()) for tests in range(Q): com,x,y=map(int,input().split()) if com==1: S[x]=y else: ANS=0 for i in range(x,y): #print(S[i],S[i+1]) ANS+=Distance[S[i]][S[i+1]] LANS.append(ANS) print("\n".join(map(str,LANS)))