def solve(N,A): last=A[0] lis=[] streak=0 for i in range(N): if last!=A[i]: lis.append(streak) streak=1 last=A[i] else: streak+=1 lis.append(streak) dp=[[False,False] for _ in range(len(lis))] dp[0]=[False,True] #0使った1使ってない for i in range(len(lis)-1): if lis[i]==1: if dp[i][1]: dp[i+1][0]=True elif dp[i][0]: dp[i+1][1]=True else: if dp[i][0] or dp[i][1]: dp[i+1][0]=True dp[i+1][1]=True if dp[-1][0]: return True else: return False T=int(input()) for _ in range(T): N=int(input()) A=list(map(int,input().split())) if solve(N,A): print('Yes') else: print('No')