Could someone explain how this code works?

1 回表示 (過去 30 日間)
IBM watson
IBM watson 2018 年 10 月 23 日
コメント済み: Torsten 2018 年 10 月 24 日
S=[1 3 0 2 0 0];
C=[0 2];
[~,col] = ismember(C,S);
S(col) = [];
S =
1 3 0 0
This code is for : exclude C from S with repetition while keeping the same order of elements in S.
But how it works?
[~,col] = ismember(C,S);

採用された回答

Guillaume
Guillaume 2018 年 10 月 23 日
編集済み: Guillaume 2018 年 10 月 23 日
I'm not sure what there is to explain. As documented, col tells you where each element corresponding element of C is found in S. If the element of C is found in more than one position, you'll get the first one of these.
The code is also flawed and will error if any element of C is not found at all in S. The safe version of the code would be:
S = [1 3 0 2 0 0];
C = [0 2 4]; %note that the original code would error because 4 is not present is S
[found, where] = ismember(C, S);
S(where(found)) = [] %this will not error
  4 件のコメント
IBM watson
IBM watson 2018 年 10 月 23 日
Many thanks to you!
Torsten
Torsten 2018 年 10 月 24 日
Note that the code from above assumes that the elements in C are distinct.
So setting
S=[1 3 0 2 0 0];
C=[0 0 2];
will not produce
S=[1 3 0]
but also
S=[1 3 0 0]
Best wishes
Torsten.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLogical についてさらに検索

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by