import java.io.*; import java.util.*; import java.text.*; import java.math.*; import java.util.regex.*; public class Solution { //ahhhhh static void addAnimal(int[][] arr, int s, int e, int m){ for (int i = 1; i <= s; i++){ for (int j = e; j < m+1; j++){ arr[i][j] = arr[i][j] + 1; } } } static int[] minimumZooNumbers(int m, int n, char[] t, int[] s, int[] d) { // Return a list of length n consisting of the answers int[][] ce = new int[m+1][m+1]; int[][] dm = new int[m+1][m+1]; for (int i = 0; i < n; i++){ char type = t[i]; int start = s[i]; int end = d[i]; if (type == 'C' || type == 'E'){ addAnimal(ce, start, end, m); }else{ addAnimal(dm, start, end, m); } } int[] ans = new int[n]; for (int i = 0; i < n; i++){ ans[i] = Integer.MAX_VALUE; } return ans; } public static void main(String[] args) { Scanner in = new Scanner(System.in); int cases = in.nextInt(); for(int a0 = 0; a0 < cases; a0++){ int m = in.nextInt(); int n = in.nextInt(); char[] t = new char[n]; for(int t_i = 0; t_i < n; t_i++){ t[t_i] = in.next().charAt(0); } int[] s = new int[n]; for(int s_i = 0; s_i < n; s_i++){ s[s_i] = in.nextInt(); } int[] d = new int[n]; for(int d_i = 0; d_i < n; d_i++){ d[d_i] = in.nextInt(); } int[] result = minimumZooNumbers(m, n, t, s, d); for (int i = 0; i < result.length; i++) { System.out.print(result[i] + (i != result.length - 1 ? " " : "")); } System.out.println(""); } in.close(); } }