pairs of consecutive numbers
3 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Lenin Cruz
am 21 Aug. 2019
Kommentiert: Ancalagon8
am 9 Dez. 2022
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 Kommentar
Akzeptierte Antwort
Guillaume
am 21 Aug. 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 Kommentare
Stephen23
am 9 Dez. 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)
Weitere Antworten (2)
Rik
am 21 Aug. 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 Kommentare
Bruno Luong
am 21 Aug. 2019
Bearbeitet: Bruno Luong
am 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 Kommentare
Siehe auch
Kategorien
Mehr zu Shifting and Sorting Matrices finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!