Boucle avant et arrière en une seule ligne


11

Je pense que c'est une question intéressante. Nous pouvons boucler dans un sens mais pouvons-nous le boucler en arrière sur la même ligne? Permettez-moi d'expliquer ce que je veux dire. Voici un exemple de code:

for(int i = 0; i < 5; i++) { // we all know the output will be 0,1,2,3,4

Je cherche s'il existe une solution de contournement pour que la déclaration ci-dessus puisse s'imprimer 0,1,2,3,4,3,2,1,0?

java 

Réponses:


14
for (int i = -4; i <= 4; i++) {
    System.out.println(4 - Math.abs(i));
}

2

Vous pouvez également vérifier ceci:

int a=1;
for(int i=0 ; i>-1 ; i+=a){
if (i==4)a=-a;
System.out.print(i +" ");
}

production :

0 1 2 3 4 3 2 1 0

2

Toute la logique en une seule ligne comme l'OP l'a demandé

  for(int i=0, d=1; i>=0 ;d=(i==4?-1:d), i+=d){
    System.out.print(i +" ");
  }

1
Cette réponse est impressionnante et plus générique que les autres (+1) - vous pouvez remplacer 0 et 4 dans les conditions de boucle pour les arguments de fonction comme min et max et puis c'est très générique! 👏
Alex L

1

Avec un peu d'arithmétique, vous pouvez:

for (int i = 0; i < 9; i++) {
    System.out.println(4 - Math.abs(4 - i));
}

Mais simplement utiliser deux forboucles est plus facile à écrire et à lire.


1

Voici

public class Main {
    public static void main(String[] args) {
        for (int i = 0, j = 8; i < 5 || j >= 0; i++, j--) {
            System.out.print((i < 5 ? i : j) + " ");
        }
    }
}

Production:

0 1 2 3 4 3 2 1 0 

1
for(int i = 0; i < 9; i++){
     int j = i;
     if(i >= 5)
         j = 8 - i;
     System.out.println(j);
}

1

Il n'y a pas de moyen vraiment simple de le faire, mais avec quelques modifications, vous pouvez vous retrouver avec une boucle qui peut changer de direction:

for(int i = 0, direction = 1; 0 <= i && i < 5; direction = (i == 5-1) ? -direction : direction, i += direction)
    System.out.println(i);

0

En Java (générique, ne doit pas nécessairement être compris entre 0 et N):

public static void forwardAndBack(int min, int max) {
  for (int i = 0; i < (max - min + 0.5) * 2; i++) {
    System.out.println((min + i) > max ? max - (min + i - max) : min + i);
  }
}
forwardAndBack(1, 4);

Dans JavaScipt (juste pour que vous puissiez voir la démo en direct):

function forwardAndBack(min, max) {
  for (let i = 0; i < (max - min + 0.5) * 2; i++) {
    console.log(min + i > max ? max - (min + i - max) : min + i);
  }
}
forwardAndBack(1, 4);
.as-console-wrapper { max-height: 100% !important; top: 0; }


0

Un liner générique, toute la logique est dans les forexpressions.

int start = 0;
int max = 4;
  for(int n= start, asc = start, desc = max * 2 - start;  
       (n = asc < desc ? asc: desc) >= start ; 
       asc++, desc--)
       {
          System.out.print(n+ " ");
       }
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.