How to get all possible combinations from two arrays in Java?











up vote
13
down vote

favorite
3












I have the two arrays:



String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};


And I want to get all possible combination in a String format like this:



48+24+12+6
48+24+12-6
48+24+12*6
48+24-12+6
48+24-12-6
48+24-12*6
..........
48*24*12*6


This what I have tried:



for(int i = 0; i < operators.length; i++) {
System.out.println(numbers[0] + operators[i] + numbers[1] + operators[i] + numbers[2] + operators[i] + numbers[3]);
}


But it only prints:



48+24+12+6
48-24-12-6
48*24*12*6


How to solve this?



This is not a duplicate because I don't want to get every two pairs of data, I want to get every combination in 4 pairs. The duplicate is different.










share|improve this question
























  • So the operators is limited, only 3?
    – ZhaoGang
    15 hours ago










  • @ZhaoGang Yes, I have only 3 operators.
    – Oleg Caralanski
    15 hours ago















up vote
13
down vote

favorite
3












I have the two arrays:



String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};


And I want to get all possible combination in a String format like this:



48+24+12+6
48+24+12-6
48+24+12*6
48+24-12+6
48+24-12-6
48+24-12*6
..........
48*24*12*6


This what I have tried:



for(int i = 0; i < operators.length; i++) {
System.out.println(numbers[0] + operators[i] + numbers[1] + operators[i] + numbers[2] + operators[i] + numbers[3]);
}


But it only prints:



48+24+12+6
48-24-12-6
48*24*12*6


How to solve this?



This is not a duplicate because I don't want to get every two pairs of data, I want to get every combination in 4 pairs. The duplicate is different.










share|improve this question
























  • So the operators is limited, only 3?
    – ZhaoGang
    15 hours ago










  • @ZhaoGang Yes, I have only 3 operators.
    – Oleg Caralanski
    15 hours ago













up vote
13
down vote

favorite
3









up vote
13
down vote

favorite
3






3





I have the two arrays:



String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};


And I want to get all possible combination in a String format like this:



48+24+12+6
48+24+12-6
48+24+12*6
48+24-12+6
48+24-12-6
48+24-12*6
..........
48*24*12*6


This what I have tried:



for(int i = 0; i < operators.length; i++) {
System.out.println(numbers[0] + operators[i] + numbers[1] + operators[i] + numbers[2] + operators[i] + numbers[3]);
}


But it only prints:



48+24+12+6
48-24-12-6
48*24*12*6


How to solve this?



This is not a duplicate because I don't want to get every two pairs of data, I want to get every combination in 4 pairs. The duplicate is different.










share|improve this question















I have the two arrays:



String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};


And I want to get all possible combination in a String format like this:



48+24+12+6
48+24+12-6
48+24+12*6
48+24-12+6
48+24-12-6
48+24-12*6
..........
48*24*12*6


This what I have tried:



for(int i = 0; i < operators.length; i++) {
System.out.println(numbers[0] + operators[i] + numbers[1] + operators[i] + numbers[2] + operators[i] + numbers[3]);
}


But it only prints:



48+24+12+6
48-24-12-6
48*24*12*6


How to solve this?



This is not a duplicate because I don't want to get every two pairs of data, I want to get every combination in 4 pairs. The duplicate is different.







java arrays algorithm






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 15 hours ago









PradyumanDixit

2,8012819




2,8012819










asked 15 hours ago









Oleg Caralanski

755




755












  • So the operators is limited, only 3?
    – ZhaoGang
    15 hours ago










  • @ZhaoGang Yes, I have only 3 operators.
    – Oleg Caralanski
    15 hours ago


















  • So the operators is limited, only 3?
    – ZhaoGang
    15 hours ago










  • @ZhaoGang Yes, I have only 3 operators.
    – Oleg Caralanski
    15 hours ago
















So the operators is limited, only 3?
– ZhaoGang
15 hours ago




So the operators is limited, only 3?
– ZhaoGang
15 hours ago












@ZhaoGang Yes, I have only 3 operators.
– Oleg Caralanski
15 hours ago




@ZhaoGang Yes, I have only 3 operators.
– Oleg Caralanski
15 hours ago












7 Answers
7






active

oldest

votes

















up vote
13
down vote



accepted










Use a triple loop:



for (int i=0; i < operators.length; ++i) {
for (int j=0; j < operators.length; ++j) {
for (int k=0; k < operators.length; ++k) {
System.out.println(numbers[0] + operators[i] + numbers[1] + operators[j] +
numbers[2] + operators[k] + numbers[3]);
}
}
}


You essentially want to take the cross product of the operators vector (if it were a vector). In Java, this translates to a triply-nested set of loops.






share|improve this answer





















  • What shall we do if we have many operators , much more than 3
    – ZhaoGang
    15 hours ago






  • 9




    This doesn't scale properly with number of operators.
    – SomeDude
    15 hours ago










  • Then we need a backtrack, but it depends on the requirement
    – ZhaoGang
    15 hours ago










  • I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
    – Oleg Caralanski
    15 hours ago








  • 2




    You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
    – MindS1
    14 hours ago


















up vote
6
down vote













While @TimBiegeleisen solution would work like a charm, its complexity might be an issue. The better approach would be a code like this:



static void combinationUtil(int arr, int n, int r, int index, int data, int i) 
{
// Current combination is ready to be printed, print it
if (index == r)
{
for (int j=0; j<r; j++)
System.out.print(data[j]+" ");

System.out.println("");

return;

}

// When no more elements are there to put in data
if (i >= n)
return;

// current is included, put next at next location
data[index] = arr[i];
combinationUtil(arr, n, r, index+1, data, i+1);

// current is excluded, replace it with next (Note that
// i+1 is passed, but index is not changed)
combinationUtil(arr, n, r, index, data, i+1);
}

// The main function that prints all combinations of size r
// in arr of size n. This function mainly uses combinationUtil()
static void printCombination(int arr, int n, int r)
{
// A temporary array to store all combination one by one
int data=new int[r];

// Print all combination using temprary array 'data'
combinationUtil(arr, n, r, 0, data, 0);
}


Source: GeeksForGeeks and my IDE :)






share|improve this answer























  • Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
    – Oleg Caralanski
    15 hours ago








  • 1




    Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
    – David Lavender
    15 hours ago






  • 2




    Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
    – Lino
    14 hours ago










  • @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
    – PradyumanDixit
    14 hours ago












  • @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
    – Solomonoff's Secret
    11 hours ago


















up vote
4
down vote













This sounds like a textbook case for a recursive solution:



public static void combineAndPrint(String pieces, String operators) {
if (pieces.length < 1) {
// no pieces? do nothing!
} else if (pieces.length == 1) {
// just one piece? no need to join anything, just print it!
System.out.println(pieces[0]);
} else {
// make a new array that's one piece shorter
String newPieces = new String[pieces.length - 1];
// copy all but the first two pieces into it
for (int i = 2; i < pieces.length; i++) {
newPieces[i - 1] = pieces[i];
}
// combine the first two pieces and recurse
for (int i = 0; i < operators.length; i++) {
newPieces[0] = pieces[0] + operators[i] + pieces[1];
combineAndPrint(newPieces, operators);
}
}
}

public static void main(String args) {
String operators = {"+", "-", "*"};
String numbers = {"48", "24", "12", "6"};
combineAndPrint(numbers, operators);
}


Try it online!



BTW, to generalize this method so that you can do more things with the generated expressions than just printing them, I would recommend making it accept an extra Consumer<String> parameter. That is, you could rewrite the method declaration as:



public static void combine(String pieces, String operators, Consumer<String> consumer) {


and replace the System.out.println(pieces[0]) with consumer.accept(pieces[0]) and the recursive call to combineAndPrint(newPieces, operators) with combine(newPieces, operators, consumer). Then just call it from your main method e.g. as:



combine(numbers, operators, s -> System.out.println(s));


Try it online!



(Of course, doing it in this more flexible way requires a somewhat modern Java version — Java 8 or later, to be specific — whereas the first example I showed above should work on even ancient versions all the way down to Java 1.0. Maybe in some future version of Java we'll get proper support for coroutines and generators, like Python and Kotlin and even modern JS already have, and then we won't even need to pass the consumer around any more.)






share|improve this answer





















  • This should be accepted.
    – Eric Wang
    9 hours ago


















up vote
3
down vote













I made an alternative, overengineered (but flexible!) "business" solution. The array lengths and values (numbers and operators) can be flexible.



package test1;

import java.io.IOException;
import java.util.ArrayList;

public class MainClass
{
public static void main(String args) throws IOException
{
String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};

ArrayList<String> strings = new MainClass().getAllPossibleCombinations(numbers, operators);

for (String string : strings)
{
System.out.println(string);
}
}

private ArrayList<String> getAllPossibleCombinations(int numbers, String operators)
{
if (numbers.length < 2) throw new IllegalArgumentException("Length of numbers-array must be at least 2");
if (operators.length < 1) throw new IllegalArgumentException("Length of operators-array must be at least 1");

ArrayList<String> returnList = new ArrayList<>();
int indexes = new int[numbers.length - 1];

while (true)
{
StringBuilder line = new StringBuilder();

for (int i = 0; i < numbers.length; i++)
{
int number = numbers[i];
line.append(number);

if (i < indexes.length)
{
line.append(operators[indexes[i]]);
}
}

returnList.add(line.toString());

try
{
this.updateIndexes(indexes, operators.length - 1);
}
catch (NoMoreCombinationsException e)
{
break;
}
}

return returnList;
}

private void updateIndexes(int currentIndexes, int maxValue) throws NoMoreCombinationsException
{
if (this.intArrayIsOnly(currentIndexes, maxValue))
{
throw new NoMoreCombinationsException();
}

for (int i = currentIndexes.length - 1; i >= 0; i--)
{
int currentIndex = currentIndexes[i];

if (currentIndex < maxValue)
{
currentIndexes[i] = currentIndex + 1;
break;
}
else
{
currentIndexes[i] = 0;
}
}
}

private boolean intArrayIsOnly(int array, int value)
{
for (int iteratedValue : array)
{
if (iteratedValue != value) return false;
}

return true;
}
}

class NoMoreCombinationsException extends Exception
{
public NoMoreCombinationsException()
{
}

public NoMoreCombinationsException(String message)
{
super(message);
}

public NoMoreCombinationsException(String message, Throwable cause)
{
super(message, cause);
}

public NoMoreCombinationsException(Throwable cause)
{
super(cause);
}

public NoMoreCombinationsException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace)
{
super(message, cause, enableSuppression, writableStackTrace);
}
}


Works like a charm :)






share|improve this answer























  • Kudos for writing clean, executable and self explanatory code :)
    – PradyumanDixit
    14 hours ago










  • Thank you too Impulse! Voted up through.
    – Oleg Caralanski
    14 hours ago










  • I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
    – findusl
    12 hours ago






  • 2




    You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
    – Jan Nielsen
    11 hours ago


















up vote
1
down vote













As already pointed out by findusl in his answer, the problem here is, strictly speaking, not to find any sort of "combination of two arrays". Instead, you basically just want to find all possible combinations of the available operators.



(The fact that you later want to "interveave" them with operands is rather unrelated to the core of the question)



So here is another option for solving this: You can create an iterable over all combinations of a certain number of elements from a certain set (in your case: the operators) and then simply combine the results with the other set (in your case: the operands).



import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.NoSuchElementException;

public class OperatorsTest
{
public static void main(String args)
{
String operators = {"+", "-", "*"};
int numbers = {48, 24, 12, 6};

CombinationIterable<String> iterable =
new CombinationIterable<String>(3, Arrays.asList(operators));
for (List<String> element : iterable)
{
System.out.println(interveave(element, numbers));
}
}

private static String interveave(List<String> operators, int numbers)
{
StringBuilder sb = new StringBuilder();
for (int i=0; i<operators.size(); i++)
{
sb.append(numbers[i]);
sb.append(operators.get(i));
}
sb.append(numbers[numbers.length-1]);
return sb.toString();
}

}

class CombinationIterable<T> implements Iterable<List<T>>
{
private final List<T> input;
private final int sampleSize;
private final int numElements;
public CombinationIterable(int sampleSize, List<T> input)
{
this.sampleSize = sampleSize;
this.input = input;
numElements = (int) Math.pow(input.size(), sampleSize);
}

@Override
public Iterator<List<T>> iterator()
{
return new Iterator<List<T>>()
{
private int current = 0;
private final int chosen = new int[sampleSize];

@Override
public boolean hasNext()
{
return current < numElements;
}

@Override
public List<T> next()
{
if (!hasNext())
{
throw new NoSuchElementException("No more elements");
}

List<T> result = new ArrayList<T>(sampleSize);
for (int i = 0; i < sampleSize; i++)
{
result.add(input.get(chosen[i]));
}
increase();
current++;
return result;
}

private void increase()
{
int index = chosen.length - 1;
while (index >= 0)
{
if (chosen[index] < input.size() - 1)
{
chosen[index]++;
return;
}
chosen[index] = 0;
index--;
}
}
};
}
}




The task resembles that of finding a set of operations that can be done with a certain number of operands and operators, and thus, this Q/A may be related. But whether or not things like associativity or commutativity should be considered here was not mentioned in the question.






share|improve this answer






























    up vote
    0
    down vote













    A bit of background information why the answers are they way they are. This problem is not really called "all possible combinations" as that is usually the problem where you can represent the elements as bits and switch them to 0 or 1 whether the element is included or not. This has a complexity of 2^N where N is the amount of operators you have. This can be solved easily in a single loop.



    However in your case you have the "urn problem with replacement and sequence". The complexity of this is N^n where n is the amount of spots you have to fill with operators. (This is often seen for pincodes where each spots can be 10 values). So because this is of higher complexity than the "all possible combinations" problem you need multiple loops or recursive calls.



    So to answer the question, "how to solve this?". You have to solve it with multiple loops or recursion because of the underlying problem's complexity.






    share|improve this answer






























      up vote
      0
      down vote













      You don't need multiple loops or recursion.



      Here's an example showcasing a limited number of loops and no recursion at all.



      int combine (int values) {
      int size = values.length;
      int combinations = 1;
      for(int i = 0; i < size; i++) {
      combinations *= size;
      }
      // or int combinations = (int)Math.pow(size, size);
      int result = new int[combinations][size];
      for(int i = 0; i < combinations; i++) {
      int index = i;
      for(int j = 0; j < size; j++) {
      result[i][j] = values[index % size];
      index /= size;
      }
      }
      return result;
      }


      If you use it with three elements, [1, 2, 3], as in the code below:



      void testCombine() {
      int combinations = combine(new int{1, 2, 3});
      for(int combination: combinations) {
      System.out.println(Arrays.toString(combination));
      }
      }


      You end up with the following result:



      [1, 1, 1]
      [2, 1, 1]
      [3, 1, 1]
      [1, 2, 1]
      [2, 2, 1]
      [3, 2, 1]
      [1, 3, 1]
      [2, 3, 1]
      [3, 3, 1]
      [1, 1, 2]
      [2, 1, 2]
      [3, 1, 2]
      [1, 2, 2]
      [2, 2, 2]
      [3, 2, 2]
      [1, 3, 2]
      [2, 3, 2]
      [3, 3, 2]
      [1, 1, 3]
      [2, 1, 3]
      [3, 1, 3]
      [1, 2, 3]
      [2, 2, 3]
      [3, 2, 3]
      [1, 3, 3]
      [2, 3, 3]
      [3, 3, 3]





      share|improve this answer























        Your Answer






        StackExchange.ifUsing("editor", function () {
        StackExchange.using("externalEditor", function () {
        StackExchange.using("snippets", function () {
        StackExchange.snippets.init();
        });
        });
        }, "code-snippets");

        StackExchange.ready(function() {
        var channelOptions = {
        tags: "".split(" "),
        id: "1"
        };
        initTagRenderer("".split(" "), "".split(" "), channelOptions);

        StackExchange.using("externalEditor", function() {
        // Have to fire editor after snippets, if snippets enabled
        if (StackExchange.settings.snippets.snippetsEnabled) {
        StackExchange.using("snippets", function() {
        createEditor();
        });
        }
        else {
        createEditor();
        }
        });

        function createEditor() {
        StackExchange.prepareEditor({
        heartbeatType: 'answer',
        convertImagesToLinks: true,
        noModals: true,
        showLowRepImageUploadWarning: true,
        reputationToPostImages: 10,
        bindNavPrevention: true,
        postfix: "",
        imageUploader: {
        brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
        contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
        allowUrls: true
        },
        onDemand: true,
        discardSelector: ".discard-answer"
        ,immediatelyShowMarkdownHelp:true
        });


        }
        });














        draft saved

        draft discarded


















        StackExchange.ready(
        function () {
        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53780951%2fhow-to-get-all-possible-combinations-from-two-arrays-in-java%23new-answer', 'question_page');
        }
        );

        Post as a guest















        Required, but never shown

























        7 Answers
        7






        active

        oldest

        votes








        7 Answers
        7






        active

        oldest

        votes









        active

        oldest

        votes






        active

        oldest

        votes








        up vote
        13
        down vote



        accepted










        Use a triple loop:



        for (int i=0; i < operators.length; ++i) {
        for (int j=0; j < operators.length; ++j) {
        for (int k=0; k < operators.length; ++k) {
        System.out.println(numbers[0] + operators[i] + numbers[1] + operators[j] +
        numbers[2] + operators[k] + numbers[3]);
        }
        }
        }


        You essentially want to take the cross product of the operators vector (if it were a vector). In Java, this translates to a triply-nested set of loops.






        share|improve this answer





















        • What shall we do if we have many operators , much more than 3
          – ZhaoGang
          15 hours ago






        • 9




          This doesn't scale properly with number of operators.
          – SomeDude
          15 hours ago










        • Then we need a backtrack, but it depends on the requirement
          – ZhaoGang
          15 hours ago










        • I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
          – Oleg Caralanski
          15 hours ago








        • 2




          You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
          – MindS1
          14 hours ago















        up vote
        13
        down vote



        accepted










        Use a triple loop:



        for (int i=0; i < operators.length; ++i) {
        for (int j=0; j < operators.length; ++j) {
        for (int k=0; k < operators.length; ++k) {
        System.out.println(numbers[0] + operators[i] + numbers[1] + operators[j] +
        numbers[2] + operators[k] + numbers[3]);
        }
        }
        }


        You essentially want to take the cross product of the operators vector (if it were a vector). In Java, this translates to a triply-nested set of loops.






        share|improve this answer





















        • What shall we do if we have many operators , much more than 3
          – ZhaoGang
          15 hours ago






        • 9




          This doesn't scale properly with number of operators.
          – SomeDude
          15 hours ago










        • Then we need a backtrack, but it depends on the requirement
          – ZhaoGang
          15 hours ago










        • I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
          – Oleg Caralanski
          15 hours ago








        • 2




          You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
          – MindS1
          14 hours ago













        up vote
        13
        down vote



        accepted







        up vote
        13
        down vote



        accepted






        Use a triple loop:



        for (int i=0; i < operators.length; ++i) {
        for (int j=0; j < operators.length; ++j) {
        for (int k=0; k < operators.length; ++k) {
        System.out.println(numbers[0] + operators[i] + numbers[1] + operators[j] +
        numbers[2] + operators[k] + numbers[3]);
        }
        }
        }


        You essentially want to take the cross product of the operators vector (if it were a vector). In Java, this translates to a triply-nested set of loops.






        share|improve this answer












        Use a triple loop:



        for (int i=0; i < operators.length; ++i) {
        for (int j=0; j < operators.length; ++j) {
        for (int k=0; k < operators.length; ++k) {
        System.out.println(numbers[0] + operators[i] + numbers[1] + operators[j] +
        numbers[2] + operators[k] + numbers[3]);
        }
        }
        }


        You essentially want to take the cross product of the operators vector (if it were a vector). In Java, this translates to a triply-nested set of loops.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 15 hours ago









        Tim Biegeleisen

        213k1386133




        213k1386133












        • What shall we do if we have many operators , much more than 3
          – ZhaoGang
          15 hours ago






        • 9




          This doesn't scale properly with number of operators.
          – SomeDude
          15 hours ago










        • Then we need a backtrack, but it depends on the requirement
          – ZhaoGang
          15 hours ago










        • I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
          – Oleg Caralanski
          15 hours ago








        • 2




          You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
          – MindS1
          14 hours ago


















        • What shall we do if we have many operators , much more than 3
          – ZhaoGang
          15 hours ago






        • 9




          This doesn't scale properly with number of operators.
          – SomeDude
          15 hours ago










        • Then we need a backtrack, but it depends on the requirement
          – ZhaoGang
          15 hours ago










        • I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
          – Oleg Caralanski
          15 hours ago








        • 2




          You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
          – MindS1
          14 hours ago
















        What shall we do if we have many operators , much more than 3
        – ZhaoGang
        15 hours ago




        What shall we do if we have many operators , much more than 3
        – ZhaoGang
        15 hours ago




        9




        9




        This doesn't scale properly with number of operators.
        – SomeDude
        15 hours ago




        This doesn't scale properly with number of operators.
        – SomeDude
        15 hours ago












        Then we need a backtrack, but it depends on the requirement
        – ZhaoGang
        15 hours ago




        Then we need a backtrack, but it depends on the requirement
        – ZhaoGang
        15 hours ago












        I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
        – Oleg Caralanski
        15 hours ago






        I only have three operators. This is what I was looking for. Saved my day!!! Thanks you so much Tim!!
        – Oleg Caralanski
        15 hours ago






        2




        2




        You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
        – MindS1
        14 hours ago




        You refer to a mathematical equation/operation that can be used to solve this problem. Would you be able to elaborate on that, or at least show the equation explicitly?
        – MindS1
        14 hours ago












        up vote
        6
        down vote













        While @TimBiegeleisen solution would work like a charm, its complexity might be an issue. The better approach would be a code like this:



        static void combinationUtil(int arr, int n, int r, int index, int data, int i) 
        {
        // Current combination is ready to be printed, print it
        if (index == r)
        {
        for (int j=0; j<r; j++)
        System.out.print(data[j]+" ");

        System.out.println("");

        return;

        }

        // When no more elements are there to put in data
        if (i >= n)
        return;

        // current is included, put next at next location
        data[index] = arr[i];
        combinationUtil(arr, n, r, index+1, data, i+1);

        // current is excluded, replace it with next (Note that
        // i+1 is passed, but index is not changed)
        combinationUtil(arr, n, r, index, data, i+1);
        }

        // The main function that prints all combinations of size r
        // in arr of size n. This function mainly uses combinationUtil()
        static void printCombination(int arr, int n, int r)
        {
        // A temporary array to store all combination one by one
        int data=new int[r];

        // Print all combination using temprary array 'data'
        combinationUtil(arr, n, r, 0, data, 0);
        }


        Source: GeeksForGeeks and my IDE :)






        share|improve this answer























        • Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
          – Oleg Caralanski
          15 hours ago








        • 1




          Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
          – David Lavender
          15 hours ago






        • 2




          Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
          – Lino
          14 hours ago










        • @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
          – PradyumanDixit
          14 hours ago












        • @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
          – Solomonoff's Secret
          11 hours ago















        up vote
        6
        down vote













        While @TimBiegeleisen solution would work like a charm, its complexity might be an issue. The better approach would be a code like this:



        static void combinationUtil(int arr, int n, int r, int index, int data, int i) 
        {
        // Current combination is ready to be printed, print it
        if (index == r)
        {
        for (int j=0; j<r; j++)
        System.out.print(data[j]+" ");

        System.out.println("");

        return;

        }

        // When no more elements are there to put in data
        if (i >= n)
        return;

        // current is included, put next at next location
        data[index] = arr[i];
        combinationUtil(arr, n, r, index+1, data, i+1);

        // current is excluded, replace it with next (Note that
        // i+1 is passed, but index is not changed)
        combinationUtil(arr, n, r, index, data, i+1);
        }

        // The main function that prints all combinations of size r
        // in arr of size n. This function mainly uses combinationUtil()
        static void printCombination(int arr, int n, int r)
        {
        // A temporary array to store all combination one by one
        int data=new int[r];

        // Print all combination using temprary array 'data'
        combinationUtil(arr, n, r, 0, data, 0);
        }


        Source: GeeksForGeeks and my IDE :)






        share|improve this answer























        • Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
          – Oleg Caralanski
          15 hours ago








        • 1




          Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
          – David Lavender
          15 hours ago






        • 2




          Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
          – Lino
          14 hours ago










        • @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
          – PradyumanDixit
          14 hours ago












        • @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
          – Solomonoff's Secret
          11 hours ago













        up vote
        6
        down vote










        up vote
        6
        down vote









        While @TimBiegeleisen solution would work like a charm, its complexity might be an issue. The better approach would be a code like this:



        static void combinationUtil(int arr, int n, int r, int index, int data, int i) 
        {
        // Current combination is ready to be printed, print it
        if (index == r)
        {
        for (int j=0; j<r; j++)
        System.out.print(data[j]+" ");

        System.out.println("");

        return;

        }

        // When no more elements are there to put in data
        if (i >= n)
        return;

        // current is included, put next at next location
        data[index] = arr[i];
        combinationUtil(arr, n, r, index+1, data, i+1);

        // current is excluded, replace it with next (Note that
        // i+1 is passed, but index is not changed)
        combinationUtil(arr, n, r, index, data, i+1);
        }

        // The main function that prints all combinations of size r
        // in arr of size n. This function mainly uses combinationUtil()
        static void printCombination(int arr, int n, int r)
        {
        // A temporary array to store all combination one by one
        int data=new int[r];

        // Print all combination using temprary array 'data'
        combinationUtil(arr, n, r, 0, data, 0);
        }


        Source: GeeksForGeeks and my IDE :)






        share|improve this answer














        While @TimBiegeleisen solution would work like a charm, its complexity might be an issue. The better approach would be a code like this:



        static void combinationUtil(int arr, int n, int r, int index, int data, int i) 
        {
        // Current combination is ready to be printed, print it
        if (index == r)
        {
        for (int j=0; j<r; j++)
        System.out.print(data[j]+" ");

        System.out.println("");

        return;

        }

        // When no more elements are there to put in data
        if (i >= n)
        return;

        // current is included, put next at next location
        data[index] = arr[i];
        combinationUtil(arr, n, r, index+1, data, i+1);

        // current is excluded, replace it with next (Note that
        // i+1 is passed, but index is not changed)
        combinationUtil(arr, n, r, index, data, i+1);
        }

        // The main function that prints all combinations of size r
        // in arr of size n. This function mainly uses combinationUtil()
        static void printCombination(int arr, int n, int r)
        {
        // A temporary array to store all combination one by one
        int data=new int[r];

        // Print all combination using temprary array 'data'
        combinationUtil(arr, n, r, 0, data, 0);
        }


        Source: GeeksForGeeks and my IDE :)







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited 14 hours ago

























        answered 15 hours ago









        PradyumanDixit

        2,8012819




        2,8012819












        • Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
          – Oleg Caralanski
          15 hours ago








        • 1




          Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
          – David Lavender
          15 hours ago






        • 2




          Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
          – Lino
          14 hours ago










        • @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
          – PradyumanDixit
          14 hours ago












        • @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
          – Solomonoff's Secret
          11 hours ago


















        • Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
          – Oleg Caralanski
          15 hours ago








        • 1




          Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
          – David Lavender
          15 hours ago






        • 2




          Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
          – Lino
          14 hours ago










        • @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
          – PradyumanDixit
          14 hours ago












        • @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
          – Solomonoff's Secret
          11 hours ago
















        Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
        – Oleg Caralanski
        15 hours ago






        Thanks PradyumanDixit I'll go with @TimBiegeleisen solution. Voted up through.
        – Oleg Caralanski
        15 hours ago






        1




        1




        Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
        – David Lavender
        15 hours ago




        Worth pointing out that recursion has its own problems: too many iterations and you'll get a StackOverflowException
        – David Lavender
        15 hours ago




        2




        2




        Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
        – Lino
        14 hours ago




        Small addition, but prefer writing the array brackets before the name and after the type: int data and not C style int data
        – Lino
        14 hours ago












        @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
        – PradyumanDixit
        14 hours ago






        @DavidLavender, yes, but, with recursion in this code, I don't think there would be problems upto fairly big numbers.
        – PradyumanDixit
        14 hours ago














        @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
        – Solomonoff's Secret
        11 hours ago




        @DavidLavender If the array were long enough to overflow the stack, the output would be too big to fit in this universe.
        – Solomonoff's Secret
        11 hours ago










        up vote
        4
        down vote













        This sounds like a textbook case for a recursive solution:



        public static void combineAndPrint(String pieces, String operators) {
        if (pieces.length < 1) {
        // no pieces? do nothing!
        } else if (pieces.length == 1) {
        // just one piece? no need to join anything, just print it!
        System.out.println(pieces[0]);
        } else {
        // make a new array that's one piece shorter
        String newPieces = new String[pieces.length - 1];
        // copy all but the first two pieces into it
        for (int i = 2; i < pieces.length; i++) {
        newPieces[i - 1] = pieces[i];
        }
        // combine the first two pieces and recurse
        for (int i = 0; i < operators.length; i++) {
        newPieces[0] = pieces[0] + operators[i] + pieces[1];
        combineAndPrint(newPieces, operators);
        }
        }
        }

        public static void main(String args) {
        String operators = {"+", "-", "*"};
        String numbers = {"48", "24", "12", "6"};
        combineAndPrint(numbers, operators);
        }


        Try it online!



        BTW, to generalize this method so that you can do more things with the generated expressions than just printing them, I would recommend making it accept an extra Consumer<String> parameter. That is, you could rewrite the method declaration as:



        public static void combine(String pieces, String operators, Consumer<String> consumer) {


        and replace the System.out.println(pieces[0]) with consumer.accept(pieces[0]) and the recursive call to combineAndPrint(newPieces, operators) with combine(newPieces, operators, consumer). Then just call it from your main method e.g. as:



        combine(numbers, operators, s -> System.out.println(s));


        Try it online!



        (Of course, doing it in this more flexible way requires a somewhat modern Java version — Java 8 or later, to be specific — whereas the first example I showed above should work on even ancient versions all the way down to Java 1.0. Maybe in some future version of Java we'll get proper support for coroutines and generators, like Python and Kotlin and even modern JS already have, and then we won't even need to pass the consumer around any more.)






        share|improve this answer





















        • This should be accepted.
          – Eric Wang
          9 hours ago















        up vote
        4
        down vote













        This sounds like a textbook case for a recursive solution:



        public static void combineAndPrint(String pieces, String operators) {
        if (pieces.length < 1) {
        // no pieces? do nothing!
        } else if (pieces.length == 1) {
        // just one piece? no need to join anything, just print it!
        System.out.println(pieces[0]);
        } else {
        // make a new array that's one piece shorter
        String newPieces = new String[pieces.length - 1];
        // copy all but the first two pieces into it
        for (int i = 2; i < pieces.length; i++) {
        newPieces[i - 1] = pieces[i];
        }
        // combine the first two pieces and recurse
        for (int i = 0; i < operators.length; i++) {
        newPieces[0] = pieces[0] + operators[i] + pieces[1];
        combineAndPrint(newPieces, operators);
        }
        }
        }

        public static void main(String args) {
        String operators = {"+", "-", "*"};
        String numbers = {"48", "24", "12", "6"};
        combineAndPrint(numbers, operators);
        }


        Try it online!



        BTW, to generalize this method so that you can do more things with the generated expressions than just printing them, I would recommend making it accept an extra Consumer<String> parameter. That is, you could rewrite the method declaration as:



        public static void combine(String pieces, String operators, Consumer<String> consumer) {


        and replace the System.out.println(pieces[0]) with consumer.accept(pieces[0]) and the recursive call to combineAndPrint(newPieces, operators) with combine(newPieces, operators, consumer). Then just call it from your main method e.g. as:



        combine(numbers, operators, s -> System.out.println(s));


        Try it online!



        (Of course, doing it in this more flexible way requires a somewhat modern Java version — Java 8 or later, to be specific — whereas the first example I showed above should work on even ancient versions all the way down to Java 1.0. Maybe in some future version of Java we'll get proper support for coroutines and generators, like Python and Kotlin and even modern JS already have, and then we won't even need to pass the consumer around any more.)






        share|improve this answer





















        • This should be accepted.
          – Eric Wang
          9 hours ago













        up vote
        4
        down vote










        up vote
        4
        down vote









        This sounds like a textbook case for a recursive solution:



        public static void combineAndPrint(String pieces, String operators) {
        if (pieces.length < 1) {
        // no pieces? do nothing!
        } else if (pieces.length == 1) {
        // just one piece? no need to join anything, just print it!
        System.out.println(pieces[0]);
        } else {
        // make a new array that's one piece shorter
        String newPieces = new String[pieces.length - 1];
        // copy all but the first two pieces into it
        for (int i = 2; i < pieces.length; i++) {
        newPieces[i - 1] = pieces[i];
        }
        // combine the first two pieces and recurse
        for (int i = 0; i < operators.length; i++) {
        newPieces[0] = pieces[0] + operators[i] + pieces[1];
        combineAndPrint(newPieces, operators);
        }
        }
        }

        public static void main(String args) {
        String operators = {"+", "-", "*"};
        String numbers = {"48", "24", "12", "6"};
        combineAndPrint(numbers, operators);
        }


        Try it online!



        BTW, to generalize this method so that you can do more things with the generated expressions than just printing them, I would recommend making it accept an extra Consumer<String> parameter. That is, you could rewrite the method declaration as:



        public static void combine(String pieces, String operators, Consumer<String> consumer) {


        and replace the System.out.println(pieces[0]) with consumer.accept(pieces[0]) and the recursive call to combineAndPrint(newPieces, operators) with combine(newPieces, operators, consumer). Then just call it from your main method e.g. as:



        combine(numbers, operators, s -> System.out.println(s));


        Try it online!



        (Of course, doing it in this more flexible way requires a somewhat modern Java version — Java 8 or later, to be specific — whereas the first example I showed above should work on even ancient versions all the way down to Java 1.0. Maybe in some future version of Java we'll get proper support for coroutines and generators, like Python and Kotlin and even modern JS already have, and then we won't even need to pass the consumer around any more.)






        share|improve this answer












        This sounds like a textbook case for a recursive solution:



        public static void combineAndPrint(String pieces, String operators) {
        if (pieces.length < 1) {
        // no pieces? do nothing!
        } else if (pieces.length == 1) {
        // just one piece? no need to join anything, just print it!
        System.out.println(pieces[0]);
        } else {
        // make a new array that's one piece shorter
        String newPieces = new String[pieces.length - 1];
        // copy all but the first two pieces into it
        for (int i = 2; i < pieces.length; i++) {
        newPieces[i - 1] = pieces[i];
        }
        // combine the first two pieces and recurse
        for (int i = 0; i < operators.length; i++) {
        newPieces[0] = pieces[0] + operators[i] + pieces[1];
        combineAndPrint(newPieces, operators);
        }
        }
        }

        public static void main(String args) {
        String operators = {"+", "-", "*"};
        String numbers = {"48", "24", "12", "6"};
        combineAndPrint(numbers, operators);
        }


        Try it online!



        BTW, to generalize this method so that you can do more things with the generated expressions than just printing them, I would recommend making it accept an extra Consumer<String> parameter. That is, you could rewrite the method declaration as:



        public static void combine(String pieces, String operators, Consumer<String> consumer) {


        and replace the System.out.println(pieces[0]) with consumer.accept(pieces[0]) and the recursive call to combineAndPrint(newPieces, operators) with combine(newPieces, operators, consumer). Then just call it from your main method e.g. as:



        combine(numbers, operators, s -> System.out.println(s));


        Try it online!



        (Of course, doing it in this more flexible way requires a somewhat modern Java version — Java 8 or later, to be specific — whereas the first example I showed above should work on even ancient versions all the way down to Java 1.0. Maybe in some future version of Java we'll get proper support for coroutines and generators, like Python and Kotlin and even modern JS already have, and then we won't even need to pass the consumer around any more.)







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 13 hours ago









        Ilmari Karonen

        36.9k566124




        36.9k566124












        • This should be accepted.
          – Eric Wang
          9 hours ago


















        • This should be accepted.
          – Eric Wang
          9 hours ago
















        This should be accepted.
        – Eric Wang
        9 hours ago




        This should be accepted.
        – Eric Wang
        9 hours ago










        up vote
        3
        down vote













        I made an alternative, overengineered (but flexible!) "business" solution. The array lengths and values (numbers and operators) can be flexible.



        package test1;

        import java.io.IOException;
        import java.util.ArrayList;

        public class MainClass
        {
        public static void main(String args) throws IOException
        {
        String operators = {"+", "-", "*"};
        int numbers = {48, 24, 12, 6};

        ArrayList<String> strings = new MainClass().getAllPossibleCombinations(numbers, operators);

        for (String string : strings)
        {
        System.out.println(string);
        }
        }

        private ArrayList<String> getAllPossibleCombinations(int numbers, String operators)
        {
        if (numbers.length < 2) throw new IllegalArgumentException("Length of numbers-array must be at least 2");
        if (operators.length < 1) throw new IllegalArgumentException("Length of operators-array must be at least 1");

        ArrayList<String> returnList = new ArrayList<>();
        int indexes = new int[numbers.length - 1];

        while (true)
        {
        StringBuilder line = new StringBuilder();

        for (int i = 0; i < numbers.length; i++)
        {
        int number = numbers[i];
        line.append(number);

        if (i < indexes.length)
        {
        line.append(operators[indexes[i]]);
        }
        }

        returnList.add(line.toString());

        try
        {
        this.updateIndexes(indexes, operators.length - 1);
        }
        catch (NoMoreCombinationsException e)
        {
        break;
        }
        }

        return returnList;
        }

        private void updateIndexes(int currentIndexes, int maxValue) throws NoMoreCombinationsException
        {
        if (this.intArrayIsOnly(currentIndexes, maxValue))
        {
        throw new NoMoreCombinationsException();
        }

        for (int i = currentIndexes.length - 1; i >= 0; i--)
        {
        int currentIndex = currentIndexes[i];

        if (currentIndex < maxValue)
        {
        currentIndexes[i] = currentIndex + 1;
        break;
        }
        else
        {
        currentIndexes[i] = 0;
        }
        }
        }

        private boolean intArrayIsOnly(int array, int value)
        {
        for (int iteratedValue : array)
        {
        if (iteratedValue != value) return false;
        }

        return true;
        }
        }

        class NoMoreCombinationsException extends Exception
        {
        public NoMoreCombinationsException()
        {
        }

        public NoMoreCombinationsException(String message)
        {
        super(message);
        }

        public NoMoreCombinationsException(String message, Throwable cause)
        {
        super(message, cause);
        }

        public NoMoreCombinationsException(Throwable cause)
        {
        super(cause);
        }

        public NoMoreCombinationsException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace)
        {
        super(message, cause, enableSuppression, writableStackTrace);
        }
        }


        Works like a charm :)






        share|improve this answer























        • Kudos for writing clean, executable and self explanatory code :)
          – PradyumanDixit
          14 hours ago










        • Thank you too Impulse! Voted up through.
          – Oleg Caralanski
          14 hours ago










        • I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
          – findusl
          12 hours ago






        • 2




          You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
          – Jan Nielsen
          11 hours ago















        up vote
        3
        down vote













        I made an alternative, overengineered (but flexible!) "business" solution. The array lengths and values (numbers and operators) can be flexible.



        package test1;

        import java.io.IOException;
        import java.util.ArrayList;

        public class MainClass
        {
        public static void main(String args) throws IOException
        {
        String operators = {"+", "-", "*"};
        int numbers = {48, 24, 12, 6};

        ArrayList<String> strings = new MainClass().getAllPossibleCombinations(numbers, operators);

        for (String string : strings)
        {
        System.out.println(string);
        }
        }

        private ArrayList<String> getAllPossibleCombinations(int numbers, String operators)
        {
        if (numbers.length < 2) throw new IllegalArgumentException("Length of numbers-array must be at least 2");
        if (operators.length < 1) throw new IllegalArgumentException("Length of operators-array must be at least 1");

        ArrayList<String> returnList = new ArrayList<>();
        int indexes = new int[numbers.length - 1];

        while (true)
        {
        StringBuilder line = new StringBuilder();

        for (int i = 0; i < numbers.length; i++)
        {
        int number = numbers[i];
        line.append(number);

        if (i < indexes.length)
        {
        line.append(operators[indexes[i]]);
        }
        }

        returnList.add(line.toString());

        try
        {
        this.updateIndexes(indexes, operators.length - 1);
        }
        catch (NoMoreCombinationsException e)
        {
        break;
        }
        }

        return returnList;
        }

        private void updateIndexes(int currentIndexes, int maxValue) throws NoMoreCombinationsException
        {
        if (this.intArrayIsOnly(currentIndexes, maxValue))
        {
        throw new NoMoreCombinationsException();
        }

        for (int i = currentIndexes.length - 1; i >= 0; i--)
        {
        int currentIndex = currentIndexes[i];

        if (currentIndex < maxValue)
        {
        currentIndexes[i] = currentIndex + 1;
        break;
        }
        else
        {
        currentIndexes[i] = 0;
        }
        }
        }

        private boolean intArrayIsOnly(int array, int value)
        {
        for (int iteratedValue : array)
        {
        if (iteratedValue != value) return false;
        }

        return true;
        }
        }

        class NoMoreCombinationsException extends Exception
        {
        public NoMoreCombinationsException()
        {
        }

        public NoMoreCombinationsException(String message)
        {
        super(message);
        }

        public NoMoreCombinationsException(String message, Throwable cause)
        {
        super(message, cause);
        }

        public NoMoreCombinationsException(Throwable cause)
        {
        super(cause);
        }

        public NoMoreCombinationsException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace)
        {
        super(message, cause, enableSuppression, writableStackTrace);
        }
        }


        Works like a charm :)






        share|improve this answer























        • Kudos for writing clean, executable and self explanatory code :)
          – PradyumanDixit
          14 hours ago










        • Thank you too Impulse! Voted up through.
          – Oleg Caralanski
          14 hours ago










        • I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
          – findusl
          12 hours ago






        • 2




          You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
          – Jan Nielsen
          11 hours ago













        up vote
        3
        down vote










        up vote
        3
        down vote









        I made an alternative, overengineered (but flexible!) "business" solution. The array lengths and values (numbers and operators) can be flexible.



        package test1;

        import java.io.IOException;
        import java.util.ArrayList;

        public class MainClass
        {
        public static void main(String args) throws IOException
        {
        String operators = {"+", "-", "*"};
        int numbers = {48, 24, 12, 6};

        ArrayList<String> strings = new MainClass().getAllPossibleCombinations(numbers, operators);

        for (String string : strings)
        {
        System.out.println(string);
        }
        }

        private ArrayList<String> getAllPossibleCombinations(int numbers, String operators)
        {
        if (numbers.length < 2) throw new IllegalArgumentException("Length of numbers-array must be at least 2");
        if (operators.length < 1) throw new IllegalArgumentException("Length of operators-array must be at least 1");

        ArrayList<String> returnList = new ArrayList<>();
        int indexes = new int[numbers.length - 1];

        while (true)
        {
        StringBuilder line = new StringBuilder();

        for (int i = 0; i < numbers.length; i++)
        {
        int number = numbers[i];
        line.append(number);

        if (i < indexes.length)
        {
        line.append(operators[indexes[i]]);
        }
        }

        returnList.add(line.toString());

        try
        {
        this.updateIndexes(indexes, operators.length - 1);
        }
        catch (NoMoreCombinationsException e)
        {
        break;
        }
        }

        return returnList;
        }

        private void updateIndexes(int currentIndexes, int maxValue) throws NoMoreCombinationsException
        {
        if (this.intArrayIsOnly(currentIndexes, maxValue))
        {
        throw new NoMoreCombinationsException();
        }

        for (int i = currentIndexes.length - 1; i >= 0; i--)
        {
        int currentIndex = currentIndexes[i];

        if (currentIndex < maxValue)
        {
        currentIndexes[i] = currentIndex + 1;
        break;
        }
        else
        {
        currentIndexes[i] = 0;
        }
        }
        }

        private boolean intArrayIsOnly(int array, int value)
        {
        for (int iteratedValue : array)
        {
        if (iteratedValue != value) return false;
        }

        return true;
        }
        }

        class NoMoreCombinationsException extends Exception
        {
        public NoMoreCombinationsException()
        {
        }

        public NoMoreCombinationsException(String message)
        {
        super(message);
        }

        public NoMoreCombinationsException(String message, Throwable cause)
        {
        super(message, cause);
        }

        public NoMoreCombinationsException(Throwable cause)
        {
        super(cause);
        }

        public NoMoreCombinationsException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace)
        {
        super(message, cause, enableSuppression, writableStackTrace);
        }
        }


        Works like a charm :)






        share|improve this answer














        I made an alternative, overengineered (but flexible!) "business" solution. The array lengths and values (numbers and operators) can be flexible.



        package test1;

        import java.io.IOException;
        import java.util.ArrayList;

        public class MainClass
        {
        public static void main(String args) throws IOException
        {
        String operators = {"+", "-", "*"};
        int numbers = {48, 24, 12, 6};

        ArrayList<String> strings = new MainClass().getAllPossibleCombinations(numbers, operators);

        for (String string : strings)
        {
        System.out.println(string);
        }
        }

        private ArrayList<String> getAllPossibleCombinations(int numbers, String operators)
        {
        if (numbers.length < 2) throw new IllegalArgumentException("Length of numbers-array must be at least 2");
        if (operators.length < 1) throw new IllegalArgumentException("Length of operators-array must be at least 1");

        ArrayList<String> returnList = new ArrayList<>();
        int indexes = new int[numbers.length - 1];

        while (true)
        {
        StringBuilder line = new StringBuilder();

        for (int i = 0; i < numbers.length; i++)
        {
        int number = numbers[i];
        line.append(number);

        if (i < indexes.length)
        {
        line.append(operators[indexes[i]]);
        }
        }

        returnList.add(line.toString());

        try
        {
        this.updateIndexes(indexes, operators.length - 1);
        }
        catch (NoMoreCombinationsException e)
        {
        break;
        }
        }

        return returnList;
        }

        private void updateIndexes(int currentIndexes, int maxValue) throws NoMoreCombinationsException
        {
        if (this.intArrayIsOnly(currentIndexes, maxValue))
        {
        throw new NoMoreCombinationsException();
        }

        for (int i = currentIndexes.length - 1; i >= 0; i--)
        {
        int currentIndex = currentIndexes[i];

        if (currentIndex < maxValue)
        {
        currentIndexes[i] = currentIndex + 1;
        break;
        }
        else
        {
        currentIndexes[i] = 0;
        }
        }
        }

        private boolean intArrayIsOnly(int array, int value)
        {
        for (int iteratedValue : array)
        {
        if (iteratedValue != value) return false;
        }

        return true;
        }
        }

        class NoMoreCombinationsException extends Exception
        {
        public NoMoreCombinationsException()
        {
        }

        public NoMoreCombinationsException(String message)
        {
        super(message);
        }

        public NoMoreCombinationsException(String message, Throwable cause)
        {
        super(message, cause);
        }

        public NoMoreCombinationsException(Throwable cause)
        {
        super(cause);
        }

        public NoMoreCombinationsException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace)
        {
        super(message, cause, enableSuppression, writableStackTrace);
        }
        }


        Works like a charm :)







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited 12 hours ago

























        answered 14 hours ago









        Impulse The Fox

        1,70011327




        1,70011327












        • Kudos for writing clean, executable and self explanatory code :)
          – PradyumanDixit
          14 hours ago










        • Thank you too Impulse! Voted up through.
          – Oleg Caralanski
          14 hours ago










        • I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
          – findusl
          12 hours ago






        • 2




          You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
          – Jan Nielsen
          11 hours ago


















        • Kudos for writing clean, executable and self explanatory code :)
          – PradyumanDixit
          14 hours ago










        • Thank you too Impulse! Voted up through.
          – Oleg Caralanski
          14 hours ago










        • I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
          – findusl
          12 hours ago






        • 2




          You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
          – Jan Nielsen
          11 hours ago
















        Kudos for writing clean, executable and self explanatory code :)
        – PradyumanDixit
        14 hours ago




        Kudos for writing clean, executable and self explanatory code :)
        – PradyumanDixit
        14 hours ago












        Thank you too Impulse! Voted up through.
        – Oleg Caralanski
        14 hours ago




        Thank you too Impulse! Voted up through.
        – Oleg Caralanski
        14 hours ago












        I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
        – findusl
        12 hours ago




        I wouldn't call it printAllPossible... That method doesn't actually print anything. Maybe generate.
        – findusl
        12 hours ago




        2




        2




        You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
        – Jan Nielsen
        11 hours ago




        You can simplify this... Make your methods static and return a boolean in updateIndexes. Avoid using exceptions in flow-control; and, favor the interface List instead of the ArrayList implementation in your APIs.
        – Jan Nielsen
        11 hours ago










        up vote
        1
        down vote













        As already pointed out by findusl in his answer, the problem here is, strictly speaking, not to find any sort of "combination of two arrays". Instead, you basically just want to find all possible combinations of the available operators.



        (The fact that you later want to "interveave" them with operands is rather unrelated to the core of the question)



        So here is another option for solving this: You can create an iterable over all combinations of a certain number of elements from a certain set (in your case: the operators) and then simply combine the results with the other set (in your case: the operands).



        import java.util.ArrayList;
        import java.util.Arrays;
        import java.util.Iterator;
        import java.util.List;
        import java.util.NoSuchElementException;

        public class OperatorsTest
        {
        public static void main(String args)
        {
        String operators = {"+", "-", "*"};
        int numbers = {48, 24, 12, 6};

        CombinationIterable<String> iterable =
        new CombinationIterable<String>(3, Arrays.asList(operators));
        for (List<String> element : iterable)
        {
        System.out.println(interveave(element, numbers));
        }
        }

        private static String interveave(List<String> operators, int numbers)
        {
        StringBuilder sb = new StringBuilder();
        for (int i=0; i<operators.size(); i++)
        {
        sb.append(numbers[i]);
        sb.append(operators.get(i));
        }
        sb.append(numbers[numbers.length-1]);
        return sb.toString();
        }

        }

        class CombinationIterable<T> implements Iterable<List<T>>
        {
        private final List<T> input;
        private final int sampleSize;
        private final int numElements;
        public CombinationIterable(int sampleSize, List<T> input)
        {
        this.sampleSize = sampleSize;
        this.input = input;
        numElements = (int) Math.pow(input.size(), sampleSize);
        }

        @Override
        public Iterator<List<T>> iterator()
        {
        return new Iterator<List<T>>()
        {
        private int current = 0;
        private final int chosen = new int[sampleSize];

        @Override
        public boolean hasNext()
        {
        return current < numElements;
        }

        @Override
        public List<T> next()
        {
        if (!hasNext())
        {
        throw new NoSuchElementException("No more elements");
        }

        List<T> result = new ArrayList<T>(sampleSize);
        for (int i = 0; i < sampleSize; i++)
        {
        result.add(input.get(chosen[i]));
        }
        increase();
        current++;
        return result;
        }

        private void increase()
        {
        int index = chosen.length - 1;
        while (index >= 0)
        {
        if (chosen[index] < input.size() - 1)
        {
        chosen[index]++;
        return;
        }
        chosen[index] = 0;
        index--;
        }
        }
        };
        }
        }




        The task resembles that of finding a set of operations that can be done with a certain number of operands and operators, and thus, this Q/A may be related. But whether or not things like associativity or commutativity should be considered here was not mentioned in the question.






        share|improve this answer



























          up vote
          1
          down vote













          As already pointed out by findusl in his answer, the problem here is, strictly speaking, not to find any sort of "combination of two arrays". Instead, you basically just want to find all possible combinations of the available operators.



          (The fact that you later want to "interveave" them with operands is rather unrelated to the core of the question)



          So here is another option for solving this: You can create an iterable over all combinations of a certain number of elements from a certain set (in your case: the operators) and then simply combine the results with the other set (in your case: the operands).



          import java.util.ArrayList;
          import java.util.Arrays;
          import java.util.Iterator;
          import java.util.List;
          import java.util.NoSuchElementException;

          public class OperatorsTest
          {
          public static void main(String args)
          {
          String operators = {"+", "-", "*"};
          int numbers = {48, 24, 12, 6};

          CombinationIterable<String> iterable =
          new CombinationIterable<String>(3, Arrays.asList(operators));
          for (List<String> element : iterable)
          {
          System.out.println(interveave(element, numbers));
          }
          }

          private static String interveave(List<String> operators, int numbers)
          {
          StringBuilder sb = new StringBuilder();
          for (int i=0; i<operators.size(); i++)
          {
          sb.append(numbers[i]);
          sb.append(operators.get(i));
          }
          sb.append(numbers[numbers.length-1]);
          return sb.toString();
          }

          }

          class CombinationIterable<T> implements Iterable<List<T>>
          {
          private final List<T> input;
          private final int sampleSize;
          private final int numElements;
          public CombinationIterable(int sampleSize, List<T> input)
          {
          this.sampleSize = sampleSize;
          this.input = input;
          numElements = (int) Math.pow(input.size(), sampleSize);
          }

          @Override
          public Iterator<List<T>> iterator()
          {
          return new Iterator<List<T>>()
          {
          private int current = 0;
          private final int chosen = new int[sampleSize];

          @Override
          public boolean hasNext()
          {
          return current < numElements;
          }

          @Override
          public List<T> next()
          {
          if (!hasNext())
          {
          throw new NoSuchElementException("No more elements");
          }

          List<T> result = new ArrayList<T>(sampleSize);
          for (int i = 0; i < sampleSize; i++)
          {
          result.add(input.get(chosen[i]));
          }
          increase();
          current++;
          return result;
          }

          private void increase()
          {
          int index = chosen.length - 1;
          while (index >= 0)
          {
          if (chosen[index] < input.size() - 1)
          {
          chosen[index]++;
          return;
          }
          chosen[index] = 0;
          index--;
          }
          }
          };
          }
          }




          The task resembles that of finding a set of operations that can be done with a certain number of operands and operators, and thus, this Q/A may be related. But whether or not things like associativity or commutativity should be considered here was not mentioned in the question.






          share|improve this answer

























            up vote
            1
            down vote










            up vote
            1
            down vote









            As already pointed out by findusl in his answer, the problem here is, strictly speaking, not to find any sort of "combination of two arrays". Instead, you basically just want to find all possible combinations of the available operators.



            (The fact that you later want to "interveave" them with operands is rather unrelated to the core of the question)



            So here is another option for solving this: You can create an iterable over all combinations of a certain number of elements from a certain set (in your case: the operators) and then simply combine the results with the other set (in your case: the operands).



            import java.util.ArrayList;
            import java.util.Arrays;
            import java.util.Iterator;
            import java.util.List;
            import java.util.NoSuchElementException;

            public class OperatorsTest
            {
            public static void main(String args)
            {
            String operators = {"+", "-", "*"};
            int numbers = {48, 24, 12, 6};

            CombinationIterable<String> iterable =
            new CombinationIterable<String>(3, Arrays.asList(operators));
            for (List<String> element : iterable)
            {
            System.out.println(interveave(element, numbers));
            }
            }

            private static String interveave(List<String> operators, int numbers)
            {
            StringBuilder sb = new StringBuilder();
            for (int i=0; i<operators.size(); i++)
            {
            sb.append(numbers[i]);
            sb.append(operators.get(i));
            }
            sb.append(numbers[numbers.length-1]);
            return sb.toString();
            }

            }

            class CombinationIterable<T> implements Iterable<List<T>>
            {
            private final List<T> input;
            private final int sampleSize;
            private final int numElements;
            public CombinationIterable(int sampleSize, List<T> input)
            {
            this.sampleSize = sampleSize;
            this.input = input;
            numElements = (int) Math.pow(input.size(), sampleSize);
            }

            @Override
            public Iterator<List<T>> iterator()
            {
            return new Iterator<List<T>>()
            {
            private int current = 0;
            private final int chosen = new int[sampleSize];

            @Override
            public boolean hasNext()
            {
            return current < numElements;
            }

            @Override
            public List<T> next()
            {
            if (!hasNext())
            {
            throw new NoSuchElementException("No more elements");
            }

            List<T> result = new ArrayList<T>(sampleSize);
            for (int i = 0; i < sampleSize; i++)
            {
            result.add(input.get(chosen[i]));
            }
            increase();
            current++;
            return result;
            }

            private void increase()
            {
            int index = chosen.length - 1;
            while (index >= 0)
            {
            if (chosen[index] < input.size() - 1)
            {
            chosen[index]++;
            return;
            }
            chosen[index] = 0;
            index--;
            }
            }
            };
            }
            }




            The task resembles that of finding a set of operations that can be done with a certain number of operands and operators, and thus, this Q/A may be related. But whether or not things like associativity or commutativity should be considered here was not mentioned in the question.






            share|improve this answer














            As already pointed out by findusl in his answer, the problem here is, strictly speaking, not to find any sort of "combination of two arrays". Instead, you basically just want to find all possible combinations of the available operators.



            (The fact that you later want to "interveave" them with operands is rather unrelated to the core of the question)



            So here is another option for solving this: You can create an iterable over all combinations of a certain number of elements from a certain set (in your case: the operators) and then simply combine the results with the other set (in your case: the operands).



            import java.util.ArrayList;
            import java.util.Arrays;
            import java.util.Iterator;
            import java.util.List;
            import java.util.NoSuchElementException;

            public class OperatorsTest
            {
            public static void main(String args)
            {
            String operators = {"+", "-", "*"};
            int numbers = {48, 24, 12, 6};

            CombinationIterable<String> iterable =
            new CombinationIterable<String>(3, Arrays.asList(operators));
            for (List<String> element : iterable)
            {
            System.out.println(interveave(element, numbers));
            }
            }

            private static String interveave(List<String> operators, int numbers)
            {
            StringBuilder sb = new StringBuilder();
            for (int i=0; i<operators.size(); i++)
            {
            sb.append(numbers[i]);
            sb.append(operators.get(i));
            }
            sb.append(numbers[numbers.length-1]);
            return sb.toString();
            }

            }

            class CombinationIterable<T> implements Iterable<List<T>>
            {
            private final List<T> input;
            private final int sampleSize;
            private final int numElements;
            public CombinationIterable(int sampleSize, List<T> input)
            {
            this.sampleSize = sampleSize;
            this.input = input;
            numElements = (int) Math.pow(input.size(), sampleSize);
            }

            @Override
            public Iterator<List<T>> iterator()
            {
            return new Iterator<List<T>>()
            {
            private int current = 0;
            private final int chosen = new int[sampleSize];

            @Override
            public boolean hasNext()
            {
            return current < numElements;
            }

            @Override
            public List<T> next()
            {
            if (!hasNext())
            {
            throw new NoSuchElementException("No more elements");
            }

            List<T> result = new ArrayList<T>(sampleSize);
            for (int i = 0; i < sampleSize; i++)
            {
            result.add(input.get(chosen[i]));
            }
            increase();
            current++;
            return result;
            }

            private void increase()
            {
            int index = chosen.length - 1;
            while (index >= 0)
            {
            if (chosen[index] < input.size() - 1)
            {
            chosen[index]++;
            return;
            }
            chosen[index] = 0;
            index--;
            }
            }
            };
            }
            }




            The task resembles that of finding a set of operations that can be done with a certain number of operands and operators, and thus, this Q/A may be related. But whether or not things like associativity or commutativity should be considered here was not mentioned in the question.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 9 hours ago

























            answered 10 hours ago









            Marco13

            41.7k854107




            41.7k854107






















                up vote
                0
                down vote













                A bit of background information why the answers are they way they are. This problem is not really called "all possible combinations" as that is usually the problem where you can represent the elements as bits and switch them to 0 or 1 whether the element is included or not. This has a complexity of 2^N where N is the amount of operators you have. This can be solved easily in a single loop.



                However in your case you have the "urn problem with replacement and sequence". The complexity of this is N^n where n is the amount of spots you have to fill with operators. (This is often seen for pincodes where each spots can be 10 values). So because this is of higher complexity than the "all possible combinations" problem you need multiple loops or recursive calls.



                So to answer the question, "how to solve this?". You have to solve it with multiple loops or recursion because of the underlying problem's complexity.






                share|improve this answer



























                  up vote
                  0
                  down vote













                  A bit of background information why the answers are they way they are. This problem is not really called "all possible combinations" as that is usually the problem where you can represent the elements as bits and switch them to 0 or 1 whether the element is included or not. This has a complexity of 2^N where N is the amount of operators you have. This can be solved easily in a single loop.



                  However in your case you have the "urn problem with replacement and sequence". The complexity of this is N^n where n is the amount of spots you have to fill with operators. (This is often seen for pincodes where each spots can be 10 values). So because this is of higher complexity than the "all possible combinations" problem you need multiple loops or recursive calls.



                  So to answer the question, "how to solve this?". You have to solve it with multiple loops or recursion because of the underlying problem's complexity.






                  share|improve this answer

























                    up vote
                    0
                    down vote










                    up vote
                    0
                    down vote









                    A bit of background information why the answers are they way they are. This problem is not really called "all possible combinations" as that is usually the problem where you can represent the elements as bits and switch them to 0 or 1 whether the element is included or not. This has a complexity of 2^N where N is the amount of operators you have. This can be solved easily in a single loop.



                    However in your case you have the "urn problem with replacement and sequence". The complexity of this is N^n where n is the amount of spots you have to fill with operators. (This is often seen for pincodes where each spots can be 10 values). So because this is of higher complexity than the "all possible combinations" problem you need multiple loops or recursive calls.



                    So to answer the question, "how to solve this?". You have to solve it with multiple loops or recursion because of the underlying problem's complexity.






                    share|improve this answer














                    A bit of background information why the answers are they way they are. This problem is not really called "all possible combinations" as that is usually the problem where you can represent the elements as bits and switch them to 0 or 1 whether the element is included or not. This has a complexity of 2^N where N is the amount of operators you have. This can be solved easily in a single loop.



                    However in your case you have the "urn problem with replacement and sequence". The complexity of this is N^n where n is the amount of spots you have to fill with operators. (This is often seen for pincodes where each spots can be 10 values). So because this is of higher complexity than the "all possible combinations" problem you need multiple loops or recursive calls.



                    So to answer the question, "how to solve this?". You have to solve it with multiple loops or recursion because of the underlying problem's complexity.







                    share|improve this answer














                    share|improve this answer



                    share|improve this answer








                    edited 12 hours ago

























                    answered 13 hours ago









                    findusl

                    737726




                    737726






















                        up vote
                        0
                        down vote













                        You don't need multiple loops or recursion.



                        Here's an example showcasing a limited number of loops and no recursion at all.



                        int combine (int values) {
                        int size = values.length;
                        int combinations = 1;
                        for(int i = 0; i < size; i++) {
                        combinations *= size;
                        }
                        // or int combinations = (int)Math.pow(size, size);
                        int result = new int[combinations][size];
                        for(int i = 0; i < combinations; i++) {
                        int index = i;
                        for(int j = 0; j < size; j++) {
                        result[i][j] = values[index % size];
                        index /= size;
                        }
                        }
                        return result;
                        }


                        If you use it with three elements, [1, 2, 3], as in the code below:



                        void testCombine() {
                        int combinations = combine(new int{1, 2, 3});
                        for(int combination: combinations) {
                        System.out.println(Arrays.toString(combination));
                        }
                        }


                        You end up with the following result:



                        [1, 1, 1]
                        [2, 1, 1]
                        [3, 1, 1]
                        [1, 2, 1]
                        [2, 2, 1]
                        [3, 2, 1]
                        [1, 3, 1]
                        [2, 3, 1]
                        [3, 3, 1]
                        [1, 1, 2]
                        [2, 1, 2]
                        [3, 1, 2]
                        [1, 2, 2]
                        [2, 2, 2]
                        [3, 2, 2]
                        [1, 3, 2]
                        [2, 3, 2]
                        [3, 3, 2]
                        [1, 1, 3]
                        [2, 1, 3]
                        [3, 1, 3]
                        [1, 2, 3]
                        [2, 2, 3]
                        [3, 2, 3]
                        [1, 3, 3]
                        [2, 3, 3]
                        [3, 3, 3]





                        share|improve this answer



























                          up vote
                          0
                          down vote













                          You don't need multiple loops or recursion.



                          Here's an example showcasing a limited number of loops and no recursion at all.



                          int combine (int values) {
                          int size = values.length;
                          int combinations = 1;
                          for(int i = 0; i < size; i++) {
                          combinations *= size;
                          }
                          // or int combinations = (int)Math.pow(size, size);
                          int result = new int[combinations][size];
                          for(int i = 0; i < combinations; i++) {
                          int index = i;
                          for(int j = 0; j < size; j++) {
                          result[i][j] = values[index % size];
                          index /= size;
                          }
                          }
                          return result;
                          }


                          If you use it with three elements, [1, 2, 3], as in the code below:



                          void testCombine() {
                          int combinations = combine(new int{1, 2, 3});
                          for(int combination: combinations) {
                          System.out.println(Arrays.toString(combination));
                          }
                          }


                          You end up with the following result:



                          [1, 1, 1]
                          [2, 1, 1]
                          [3, 1, 1]
                          [1, 2, 1]
                          [2, 2, 1]
                          [3, 2, 1]
                          [1, 3, 1]
                          [2, 3, 1]
                          [3, 3, 1]
                          [1, 1, 2]
                          [2, 1, 2]
                          [3, 1, 2]
                          [1, 2, 2]
                          [2, 2, 2]
                          [3, 2, 2]
                          [1, 3, 2]
                          [2, 3, 2]
                          [3, 3, 2]
                          [1, 1, 3]
                          [2, 1, 3]
                          [3, 1, 3]
                          [1, 2, 3]
                          [2, 2, 3]
                          [3, 2, 3]
                          [1, 3, 3]
                          [2, 3, 3]
                          [3, 3, 3]





                          share|improve this answer

























                            up vote
                            0
                            down vote










                            up vote
                            0
                            down vote









                            You don't need multiple loops or recursion.



                            Here's an example showcasing a limited number of loops and no recursion at all.



                            int combine (int values) {
                            int size = values.length;
                            int combinations = 1;
                            for(int i = 0; i < size; i++) {
                            combinations *= size;
                            }
                            // or int combinations = (int)Math.pow(size, size);
                            int result = new int[combinations][size];
                            for(int i = 0; i < combinations; i++) {
                            int index = i;
                            for(int j = 0; j < size; j++) {
                            result[i][j] = values[index % size];
                            index /= size;
                            }
                            }
                            return result;
                            }


                            If you use it with three elements, [1, 2, 3], as in the code below:



                            void testCombine() {
                            int combinations = combine(new int{1, 2, 3});
                            for(int combination: combinations) {
                            System.out.println(Arrays.toString(combination));
                            }
                            }


                            You end up with the following result:



                            [1, 1, 1]
                            [2, 1, 1]
                            [3, 1, 1]
                            [1, 2, 1]
                            [2, 2, 1]
                            [3, 2, 1]
                            [1, 3, 1]
                            [2, 3, 1]
                            [3, 3, 1]
                            [1, 1, 2]
                            [2, 1, 2]
                            [3, 1, 2]
                            [1, 2, 2]
                            [2, 2, 2]
                            [3, 2, 2]
                            [1, 3, 2]
                            [2, 3, 2]
                            [3, 3, 2]
                            [1, 1, 3]
                            [2, 1, 3]
                            [3, 1, 3]
                            [1, 2, 3]
                            [2, 2, 3]
                            [3, 2, 3]
                            [1, 3, 3]
                            [2, 3, 3]
                            [3, 3, 3]





                            share|improve this answer














                            You don't need multiple loops or recursion.



                            Here's an example showcasing a limited number of loops and no recursion at all.



                            int combine (int values) {
                            int size = values.length;
                            int combinations = 1;
                            for(int i = 0; i < size; i++) {
                            combinations *= size;
                            }
                            // or int combinations = (int)Math.pow(size, size);
                            int result = new int[combinations][size];
                            for(int i = 0; i < combinations; i++) {
                            int index = i;
                            for(int j = 0; j < size; j++) {
                            result[i][j] = values[index % size];
                            index /= size;
                            }
                            }
                            return result;
                            }


                            If you use it with three elements, [1, 2, 3], as in the code below:



                            void testCombine() {
                            int combinations = combine(new int{1, 2, 3});
                            for(int combination: combinations) {
                            System.out.println(Arrays.toString(combination));
                            }
                            }


                            You end up with the following result:



                            [1, 1, 1]
                            [2, 1, 1]
                            [3, 1, 1]
                            [1, 2, 1]
                            [2, 2, 1]
                            [3, 2, 1]
                            [1, 3, 1]
                            [2, 3, 1]
                            [3, 3, 1]
                            [1, 1, 2]
                            [2, 1, 2]
                            [3, 1, 2]
                            [1, 2, 2]
                            [2, 2, 2]
                            [3, 2, 2]
                            [1, 3, 2]
                            [2, 3, 2]
                            [3, 3, 2]
                            [1, 1, 3]
                            [2, 1, 3]
                            [3, 1, 3]
                            [1, 2, 3]
                            [2, 2, 3]
                            [3, 2, 3]
                            [1, 3, 3]
                            [2, 3, 3]
                            [3, 3, 3]






                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited 4 hours ago

























                            answered 4 hours ago









                            Olivier Grégoire

                            14.7k1663100




                            14.7k1663100






























                                draft saved

                                draft discarded




















































                                Thanks for contributing an answer to Stack Overflow!


                                • Please be sure to answer the question. Provide details and share your research!

                                But avoid



                                • Asking for help, clarification, or responding to other answers.

                                • Making statements based on opinion; back them up with references or personal experience.


                                To learn more, see our tips on writing great answers.





                                Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                                Please pay close attention to the following guidance:


                                • Please be sure to answer the question. Provide details and share your research!

                                But avoid



                                • Asking for help, clarification, or responding to other answers.

                                • Making statements based on opinion; back them up with references or personal experience.


                                To learn more, see our tips on writing great answers.




                                draft saved


                                draft discarded














                                StackExchange.ready(
                                function () {
                                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53780951%2fhow-to-get-all-possible-combinations-from-two-arrays-in-java%23new-answer', 'question_page');
                                }
                                );

                                Post as a guest















                                Required, but never shown





















































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown

































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown







                                Popular posts from this blog

                                Plaza Victoria

                                In PowerPoint, is there a keyboard shortcut for bulleted / numbered list?

                                How to put 3 figures in Latex with 2 figures side by side and 1 below these side by side images but in...