Return to the start of a loop
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
googo
le 16 Avr 2013
Réponse apportée : Soheyl Khajehpour-Tadavani
le 23 Sep 2020
Hello,
I'm writing a function which returns the sequences of n requested letters in a string. For example, :
string = 'abcad' , n=3
ans =
abc
bca
cad
Well, my code is :
function s=ngramsFreq(string,n)
k=0;
t = repmat(char(0),length(string)-n+1,n);
for i=1:(length(string)-n)+1
k=k+1;
for j=1:n
for m=k:(k+n)-1
t(i,j)=string(m);
break
end
end
end
s=t;
end
When I'm runing the program for 'abcad', n=3 the function returns:
ngramsFreq('abcad',3)
ans =
aaa
bbb
ccc
I think the problem is in the inside loop:
for m=k:(k+n)-1
t(i,j)=string(m);
break
end
I want it to end after one step and not keep looping. For example After t(1,1)=string(1) go to j=2 and not return to m=1.
Any help with this? thank you very much!
Note: For the meantime, if a sequence is showing twice or more the function will return both sequences or how many there is (for example: 'aaa' will return [aa;aa].
0 commentaires
Réponse acceptée
Andrei Bobrov
le 16 Avr 2013
Modifié(e) : Andrei Bobrov
le 16 Avr 2013
str = 'abcad' ;
n=3;
out = str( hankel(1:n,n:numel(str)) );
without hankel
out = str( bsxfun(@plus,1:n,(0:numel(str) - n)') )
with while-loop
g = 1:n;
out = [];
while g(end) <= numel(str)
out = [out;str(g)];
g = g + 1;
end
3 commentaires
Plus de réponses (2)
Yao Li
le 16 Avr 2013
function s=ngramsFreq(string,n)
k=0;
t = repmat(char(0),length(string)-n+1,n);
for i=1:(length(string)-n)+1
k=k+1;
t(i,1:n)=string(k:1:(k+n)-1);
end
s=t;
end
7 commentaires
Yao Li
le 16 Avr 2013
You can divide your algorithm to 2 steps: 1st find the specific group of letters. 2nd remove the repeated groups
Soheyl Khajehpour-Tadavani
le 23 Sep 2020
Hi
I am writing a code for calculating a parameter with if clauses. How does the code can return when it does not satisfy my if calculation?
thank you
0 commentaires
Voir également
Catégories
En savoir plus sur Call Python from MATLAB 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!