import sys input = sys.stdin.readline def calc(A): N=len(A) if A==[1]*N: return "No" flag=1 B=[] for a in A: if B and B[-1]==1 and a==1: continue else: B.append(a) while B and B[0]==1 and B[-1]==1: B.pop() for i in range(len(B)): if B[i]==2 and B[i-1]==2: flag=0 if B[i]==0 and B[i-1]==0: flag=0 if B[i]==1: if B[i-1]==B[(i+1)%len(B)]==2: flag=0 if B[i-1]==B[(i+1)%len(B)]==0: flag=0 if flag==0: return "No" if sum(A)==N: return "Yes" else: return "No" T=int(input()) for tests in range(T): N=int(input()) A=list(map(int,input().split())) print(calc(A))