MATLAB: Match index of arrays

matching arrays

Hi, I have a problem with matching and indexing. The problem was raised in this forum earlier and was solved. This is how it was raised
A = [9 10 11 12 13 14 15 16 17]'
B = [10 13 16; 999 900 950]'
The desired solution is
M =
9 0
10 999
11 0
12 0
13 900
14 0
15 0
16 950
17 0
This can be attained as follows
M = A*[1 0]
M(ismember(A,B(:,1)),2) = B(:,2)
My problem is exactly the same but the solution is not working. The only difference I have is the size of A and B
A is too large and is of size(A)
ans =
1035593 1
B is small and is of size(B)
ans =
72 2
Column 1 of B contains unique ids that match unique ids in A. Column 2 is the data to be matched given ids.
When I apply the solution above, I get Subscripted assignment dimension mismatch. I am not sure why this is happening, could you kindly advise or provide an alternative solution.

Best Answer

You would get that error if there are columns in B that are not matched in A.
[~, ia, ib] = intersect(A, B(:,1));
M(ia,:) = B(ib,:);