Javascript tömb manipuláció és loop

szavazat
0

Kimenete az alábbi kódot kap a program után. Meg kell iterálására j értéke a következő sorrendben (1,2,3,4), (2,3,4,1), (3,4,1,2), (4,1,2,3), de ez annak érdekében, az (1,2,3,4), (2,3,4), (3,4), (4). Minden segítséget előre is köszönjük

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

Kimenet

i értéke 0, j értéke 1 ,030000000000000027

i értéke 0 j értéke 2 -0,21999999999999997

i értéke 0 j jelentése 3 1,92

i értéke 0 j jelentése 4 0,030000000000000027

3

i értéke 1, j értéke 2 -0.25

i értéke 1, j értéke 3 1,8900000000000001

i értéke 1, j értéke 4 0

2

i értéke 2 j jelentése 3 2,14

i értéke 2, j értéke 4 0,25

0

i 3 j 4 -1,8900000000000001

1

A kérdést 24/10/2019 12:00
a forrás felhasználó
Más nyelveken...                            


5 válasz

szavazat
0

Be kell állítani az j 0, amikor a végén a tömb. És a dupla hurok használhatatlan.

var i=0;
var j=i;
for(i=0; i<arrayLength ; i++){
    j++;
    if(j==arrayLength){
        j=0;
    }
    //Do your stuff
}
Válaszolt 24/10/2019 12:14
a forrás felhasználó

szavazat
0

Ahelyett, hogy a bonyolult hurok, akkor csak shift elem az elejétől a végéig.

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

Válaszolt 24/10/2019 12:19
a forrás felhasználó

szavazat
0

Csak nyomtatni a sorrendben van szüksége, próbálja meg ezt:

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

Válaszolt 24/10/2019 12:43
a forrás felhasználó

szavazat
0

A szigorúan csinálni, amit akar:

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
}
Válaszolt 24/10/2019 12:54
a forrás felhasználó

szavazat
0

Csak egy kis modulus varázslat tehet ő munkát az Ön számára

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
  }
}
Válaszolt 24/10/2019 13:01
a forrás felhasználó

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