Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
334 views
in Technique[技术] by (71.8m points)

java - Simulating nested loops

In a beginner's programming book (free licence) there was the following code, dynamically creating nested loops in Java:

public class RecursiveNestedLoops {
  public static int numberOfLoops;
  public static int numberOfIterations;
  public static int[] loops;

  public static void main(String[] args) {
    Scanner input = new Scanner(System.in);
    System.out.print("N = ");
    numberOfLoops = input.nextInt();
    System.out.print("K = ");
    numberOfIterations = input.nextInt();
    input.close();
    loops = new int[numberOfLoops];
    nestedLoops(0);
  }

  public static void nestedLoops(int currentLoop) {
    if (currentLoop == numberOfLoops) {
      printLoops();
      return;
    }
    for (int counter = 1; counter <= numberOfIterations; counter++) {
      loops[currentLoop] = counter;
      nestedLoops(currentLoop + 1);
    }
  }

  public static void printLoops() {
    for (int i = 0; i < numberOfLoops; i++) {
      System.out.printf("%d ", loops[i]);
    }
    System.out.println();
  }
}

When inputting N=2 and K=3, on the screen should be printed something like [1,1],[1,2],[1,3],[2,1],[2,2],[2,3],[3,1],[3,2],[3,3] (with newlines, etc). The program works fine. Then I tried to debug it and spent a quite some time trying to understand how exactly it works. I couldn't.

My question: why after printing [1,3] the variable 'curentLoop' becomes '0' being beforehand '1' ?

Also: In my debugger (Eclipse built-in) after printing [1,3] the pointer goes to the end '}' brace of the method 'nestedLoops' (with 'currentLoop' with value 1), and then suddenly it starts executing the for-loop with 'currentLoop' = 0. Where does the variable take its value '0' from? Why after going to the end brace of the method, it starts executing the 'for loop', without any call to the method's name?

This could be a very easy question to some of you; I'm just a beginner.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Because it's a recursive call to nested loops. first, it is called with 0. then it is called with 1. then with 2. when it gets to the number of total loops, it begins executing the loops (this is called the recursive terminal condition). however, each call to nested loops is placed on the stack, it executes k, then returns and executes k-1, then returns and executes k-2, then returns and executes k-3 all the way down to k - k = 0.

if i were you, i would place a breakpoint on the call of nestedloops() inside itself and watch what it is being called with. then, as it is called, watch it work its way back down.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...