pairs of consecutive numbers
7 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello,
I have a vector A=[1 2 5] i would like to have something that stores the pair of consecutive numbers eg B= [1 2] and something that stores the values unused eg [C= 5]
i would like this working for A=[5 2 1], A=[5 1 2] and all the permutations of the elements .
Thanks
Here is some piece of code that I have tried but I have no idea how to get the element unused, 'C' in my example above
A= [6 3 4];
p=[find(diff(A)==1); find(diff(A) == -1)];
q=[p;p+1];
A(q)
1 commentaire
Réponse acceptée
Guillaume
le 21 Août 2019
Well, you're almost there. When the diff is 1 or -1, this means that the number at the same index and the next one are consecutive. The easiest way to find the non-consecutive numbers is to take the set difference of all the indices with the pair indices.
A = [6 2 3 2 4 1 3 2 1 0 5]
pairindices = find(ismember(diff(A), [-1, 1])) + [0;1] %assumes A is a row vector
nonconsindices = setdiff(1:numel(A), pairindices)
Another method, which uses the undocumented feature that strfind works with numeric vectors:
nonconsindices = strfind([0, abs(diff(A)) == 1, 0], [0, 0])
13 commentaires
Stephen23
le 9 Déc 2022
"from row position 14 to 19, 33 to 36 etc to assign these number to dates (14-Jan to 19-Jan, 02-Febr to 05-Febr)"
V = [14;19;33;36];
D = datetime(2022,1,V)
Plus de réponses (2)
Rik
le 21 Août 2019
I have expanded your example array a bit to more clearly show the indeded effect. I have replicated the effect of your code, please confirm that is what you meant.
A=[3 1 2 0 3 4 5];
L= abs(diff(A))==1;
L=[L false;false L];
L_unused= sum(L,1)==0 ;
B=[A(L(1,:));A(L(2,:))];
C=A(L_unused);
2 commentaires
Bruno Luong
le 21 Août 2019
Modifié(e) : Bruno Luong
le 29 Nov 2022
A=[5 3 4 1];
As=sort(A);
b=diff(As)==1;
pairs=As(b)'+[0 1];
notpair = setdiff(A,pairs(:))
0 commentaires
Voir également
Catégories
En savoir plus sur Shifting and Sorting Matrices dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!