Javascript Array manipulatie en looping

stemmen
0

Uitgang van de volgende code wordt gegeven na het programma. Ik moet j waarde in de volgende volgorde (1,2,3,4) herhalen, (2,3,4,1), (3,4,1,2), (4,1,2,3), maar het in volgorde van (1,2,3,4), (2,3,4), (3,4), (4). Alle hulp wordt zeer gewaardeerd

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>);
}      

uitgang

i 0 j 1 ,030000000000000027

i 0 j 2 -,21999999999999997

i 0 j 3 1,92

i 0 j 4 ,030000000000000027

3

i 1 j 2 -0.25

i 1 j 3 1,8900000000000001

i 1 j 4 0

2

i 2 j 3 2.14

i 2 j 4 0,25

0

i 3 j 4 -1,8900000000000001

1

De vraag is gesteld op 24/10/2019 om 12:00
bron van user
In andere talen...                            


5 antwoorden

stemmen
0

U moet j ingesteld op 0 als het gaat om het einde van de array. En de dubbele lus is nutteloos.

var i=0;
var j=i;
for(i=0; i<arrayLength ; i++){
    j++;
    if(j==arrayLength){
        j=0;
    }
    //Do your stuff
}
antwoordde op 24/10/2019 om 12:14
bron van user

stemmen
0

In plaats van het managen van complexe looping, kunt u gewoon verschuiven uw element van begin tot einde.

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>");
} 

antwoordde op 24/10/2019 om 12:19
bron van user

stemmen
0

Gewoon om af te drukken in de volgorde die u nodig hebt, probeer dan deze:

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>");
}

antwoordde op 24/10/2019 om 12:43
bron van user

stemmen
0

Strikt doen wat je wilt:

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
}
antwoordde op 24/10/2019 om 12:54
bron van user

stemmen
0

Gewoon een beetje van modulus magie kan hij doen Job voor u

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
  }
}
antwoordde op 24/10/2019 om 13:01
bron van user

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