Laço frontal e traseiro em uma linha

11

Eu acho que essa é uma pergunta interessante. Podemos fazer um loop de uma maneira, mas podemos fazer um loop para trás na mesma linha? Deixe-me explicar o que quero dizer. Aqui está um exemplo de código:

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

Estou procurando se há alguma solução alternativa para que a declaração acima possa ser impressa 0,1,2,3,4,3,2,1,0?


fonte

Respostas:

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

Você também pode verificar isso:

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

resultado :

0 1 2 3 4 3 2 1 0
Freeman
fonte
2

Toda a lógica em uma linha como o OP pediu

  for(int i=0, d=1; i>=0 ;d=(i==4?-1:d), i+=d){
    System.out.print(i +" ");
  }
Ken
fonte
11
Essa resposta é impressionante e mais genérica que as demais (+1) - você pode substituir 0 e 4 nas condições do loop por argumentos de função como min e max e, em seguida, é muito genérico! 👏
Alex L
1

Com um pouco de aritmética, você pode:

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

Mas simplesmente usar dois forloops é mais fácil de escrever e ler.

Thomas
fonte
1

Aqui está

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

Resultado:

0 1 2 3 4 3 2 1 0 
Arvind Kumar Avinash
fonte
1
for(int i = 0; i < 9; i++){
     int j = i;
     if(i >= 5)
         j = 8 - i;
     System.out.println(j);
}
Delphi1024
fonte
1

Não há realmente uma maneira simples de fazer isso, mas com algumas modificações você pode acabar com um loop que pode mudar de direção:

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

Em Java (genérico, não precisa estar entre 0 e 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);

No JavaScipt (apenas para ver a demonstração ao vivo):

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

Alex L
fonte
0

Um liner genérico, toda a lógica está nas forexpressões.

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