find first& end of array
조회 수: 3 (최근 30일)
이전 댓글 표시
채택된 답변
Stephen23
2022년 5월 20일
S = [0,1,5,2,0,0,0,9,3,50,53,0,0,5,7,4]
X = diff([0;S(:)]==0)<0 | diff([S(:);0]==0)>0;
V = S(X)
댓글 수: 0
추가 답변 (2개)
the cyclist
2022년 5월 20일
I expect someone will post a more elegant method, but I think this does what you want
S=[0 1 5 2 0 0 0 9 3 50 53 0 0 5 7 4];
first = S(diff([0 S]) == S & S~=0);
last = S(diff([S 0]) ==-S & S~=0);
firstLast = [first; last];
output = firstLast(:)'
댓글 수: 0
Image Analyst
2022년 5월 20일
Here's a different way:
S=[0 1 5 2 0 0 0 9 3 50 53 0 0 5 7 4];
S2 = [0,S,0];
indexes = sort([strfind(S2~=0, [0 1]) + 1, strfind(S2~=0, [1,0])])
S3 = S2(indexes)
댓글 수: 0
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!