ref:https://blog.csdn.net/u010142437/article/details/23712507/
https://blog.csdn.net/zlk961543260/article/details/70240714
向量中的那些唯一的元素
语法
b = unique(A)
b = unique(A,'rows')
[b,m,n] = unique(...)
描述
1、b = unique(A) 返回的是和A中一样的值,但是没有重复元素。产生的结果向量按升序排序。A可以是一个字符串的单元阵列。
2、b = unique(A,'rows') 返回的是A中的唯一的行数。
3、[b,m,n] = unique(...) 也返回索引向量m和n,使得B = A(M)和A= B(N)。m的每一个元素是最大的下标,使得B = A(M)。对于行的组合,B = A(M,:)和A= B(N,:)。
示例
A = [1 1 5 6 2 3 3 9 8 6 2 4]
A =
1 1 5 6 2 3 3 9 8 6 2 4
[b,m,n] = unique(A)
b =
1 2 3 4 5 6 8 9
m =
2 11 7 12 3 10 9 8
n =
1 1 5 6 2 3 3 8 7 6 2 4
A(m)
ans =
1 2 3 4 5 6 8 9
b(n)
ans =
1 1 5 6 2 3 3 9 8 6 2 4
因为NaN是互不相等的,把他们作为独特的元素对待
unique([1 1 NaN NaN])
ans =
1 NaN NaN
ismember函数
a=[1 2 3 4 5];
b=[3 4 5 6 7];
c=[2 4 6 8 10];
ismember(a,b)
[lia,lib]=ismember(a,c)
直接复制代码到MATLAB运行窗口,可以看到结果如下:
ans =
0 0 1 1 1
lia =
0 1 0 1 0
lib =
0 1 0 2 0
那么结果是什么意思呢,这个函数主要是看矩阵a中的数是不是矩阵b中的成员,是的话结果返回1,不是返回0;这就是ismember(a,b)结果为什么是0 0 1 1 1,这个不用再多解释了吧!(这个结果是基于矩阵a的,意思是结果为什么是0 0 1 1 1,而不是 1 1 1 0 0)
第二种用法,就是返回值是两个矩阵,第一个矩阵跟上面的结果一样,因此lia = 0 1 0 1 0;第二个矩阵大家也许猜到了,第一个矩阵中的元素是第二个矩阵的成员的时候,看看这个值在第二个矩阵中的索引,也就是说a中2,4是c中的成员,2,4在c中的索引也就是下标为1,2。
看到评论区留言,下面补充一下:
注意(特殊情况):第二种用法的时候,如果第一个矩阵中的某些值在第二个矩阵有多个相同的存在,或者是第一个矩阵有多相同的值在第二矩阵中有一个或多个相同存在,那么返回的就一直是在第二个矩阵该值首先出现的位置记号。如果
c=[2 4 2 8 10];
a=[1 2 3 4 5];
[lia,lib]=ismember(a,c);
lib=[0 1 0 2 0]
或者是
c=[2 4 2 8 10];
a=[1 2 3 2 2];
[lia,lib]=ismember(a,c);
lib=[0 1 0 1 1]