Javascript manipulation et mise en boucle tableau

voix
0

Sortie du code suivant est donné après le programme. Je dois itérer valeur j dans l'ordre suivant (1,2,3,4), (2,3,4,1), (3,4,1,2), (4,1,2,3), mais il est dans l'ordre de (1,2,3,4), (2,3,4), (3,4), (4). Toute aide est très appréciée

var RRIntervalArrayDiff = [];
var validRRIntervalCount =0;
var RRIntervalArrayy = [0.62,0.65,0.40,2.54,0.65];
var n = RRIntervalArrayy.length;
for (i=0; i < n; i++){
    for (j=i+1; j<n ;j++){
        document.write(</br>);
        document.write(i is +i+ j is +j);
        var h = (RRIntervalArrayy[j] - RRIntervalArrayy[i]);
        document.write(</br>);
        if(h < 0.12){
            validRRIntervalCount++;
        }
        document.write(h);
        if(j==(n-1)){
            document.write(</br>);
            document.write(validRRIntervalCount)
            break;
        }
    }    
    validRRIntervalCount = 0;
    document.write(</br>);
}      

sortie

i est égal à 0 j est égal à 1 0,030000000000000027

i est égal à 0 j est égal à 2 -0,21999999999999997

i est égal à 0 j est égal à 3 1,92

i est égal à 0 j est 4 ,030000000000000027

3

i est 1 j est égal à 2 -0,25

i est 1 j est égal à 3 1,8900000000000001

i est 1 j est 4 0

2

i est 2 j est égal à 3 2,14

i est 2 j est 4 0,25

0

i est 3 j est 4 -1,8900000000000001

1

Créé 24/10/2019 à 12:00
source utilisateur
Dans d'autres langues...                            


5 réponses

voix
0

Vous devez définir j 0 comme quand il arrive à la fin du tableau. Et la double boucle est inutile.

var i=0;
var j=i;
for(i=0; i<arrayLength ; i++){
    j++;
    if(j==arrayLength){
        j=0;
    }
    //Do your stuff
}
Créé 24/10/2019 à 12:14
source utilisateur

voix
0

Au lieu de gérer looping complexe, vous pouvez simplement changer votre élément du début à la fin.

RRIntervalArrayy.push (RRIntervalArrayy.shift ());

var RRIntervalArrayDiff = [];
var validRRIntervalCount =0;
var RRIntervalArrayy = [0.62,0.65,0.40,2.54,0.65];
var n = RRIntervalArrayy.length;
for (i=0; i < n; i++){
document.write("--------------------------------");
document.write("</br>");
    for (j=0; j<n ;j++){
        document.write("</br>");
        document.write("array element is:" + RRIntervalArrayy[j] );
        var h = (RRIntervalArrayy[j] - RRIntervalArrayy[i]);
        document.write("</br>");
        if(h < 0.12){
            validRRIntervalCount++;
        }
        document.write(h);
        if(j==(n-1)){
            document.write("</br>");
            document.write(validRRIntervalCount)
            break;
        }
    }
   
    RRIntervalArrayy.push(RRIntervalArrayy.shift());
    validRRIntervalCount = 0;
    document.write("</br>");
} 

Créé 24/10/2019 à 12:19
source utilisateur

voix
0

Juste pour imprimer dans l'ordre dont vous avez besoin, essayez ceci:

var RRIntervalArrayDiff = [];
var validRRIntervalCount =0;
var RRIntervalArrayy = [0.62,0.65,0.40,2.54,0.65];
var n = RRIntervalArrayy.length;
  var revert = 0;
for (i=0; i < n; i++){
  revert = 0;
     for (j=i+1; j< n ;j++){
       if(revert == 1 && j == i){
         break;
       }else if(revert == 1 && j != i){
        document.write(j + 1);
         continue;
       }
        document.write(j);
        if(j==(n-1)){
          if(revert == 0){
            j = -1;
            revert = 1;
          }
        }
    }    
    validRRIntervalCount = 0;
    document.write("</br>");
}

Créé 24/10/2019 à 12:43
source utilisateur

voix
0

Pour ce faire strictement ce que vous voulez:

for (i=0; i < n; i++){
  var j = i + 1
  var count = 0
  while (count < n-1){
    if (j == n)
      j = 1
    // do your stuff
    count++
    j++
  }
// do your stuff
}
Créé 24/10/2019 à 12:54
source utilisateur

voix
0

Juste un peu de magie module peut faire il travail pour vous

var RRIntervalArrayDiff = [];
var validRRIntervalCount = 0;
var RRIntervalArrayy = [0.62, 0.65, 0.40, 2.54, 0.65];
var n = RRIntervalArrayy.length;
for (i = 0; i < n; i++) {
  for (j = i; j < n + i; j++) {
    var newJ = j % (n) + 1;
    //use newJ instead of j in your calculations
  }
}
Créé 24/10/2019 à 13:01
source utilisateur

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more