Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8489711
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 10, 20262026-06-10T21:54:15+00:00 2026-06-10T21:54:15+00:00

Possible Duplicate: Generating all permutations of a given string Given a length n=4, and

  • 0

Possible Duplicate:
Generating all permutations of a given string

Given a length n=4,
and a set of characters -> {'a', 'b'},
how to write some java codes to produce all the possible string with that length n containing the characters in the set?

For the example above, the result should have 2^4=16 strings, which is:

aaaa
aaab
aabb
abbb
baaa
baab
babb
bbbb
bbaa
bbab
bbba
abaa
abab
abba
baba
aaba

here is my code snippet:

public void process(String result, String string)
{
    if(string.length() == 0)
    {
        System.out.println(result);
    }else{
        for(int i = 0; i < string.length(); i++)
        {
            String newResult = new String(result+string.charAt(i));
            String newString = new String(string.substring(0,i) + string.substring(i+1, string.length()));
            process(newResult, newString);
        }
    }
}

That seems like only doing permutation, instead of what I want…….
Thank you in advance 🙂

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-10T21:54:16+00:00Added an answer on June 10, 2026 at 9:54 pm

    Think of it in the same way you would counting. You’re technically “counting” from aaaa to bbbb, like binary.

    aaaa -> 0000
    aaab -> 0001
    aaba -> 0010
    aabb -> 0011
    ...
    bbbb -> 1111
    

    Without seeing what you’ve tried, I can’t help you more than that, but essentially you need to enumerate all the “numbers” between your “lowest” element and your “highest” element by counting up through them.

    For higher element counts, just treat your counting as counting in a higher base. For eight elements, Set = {a, b, c, d, e, f, g, h}, you would be counting up in what’s essentially octal:

    aaaa -> 0000
    aaab -> 0001
    ...
    aaah -> 0007
    aaba -> 0010
    ...
    hhhh -> 7777
    

    It’s the same way you enumerate all the combinations of 0-9 with a length of 4, by counting from 0000 to 9999.

    Edit:

    Thank you for posting your code. You’re correct, you’re doing permutations. A better way would be to use a multi-combination (combination with repeated elements in the ordererd combination set) algorithm like the one discussed here.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Possible Duplicate: Developing for Android in Eclipse: R.java not generating what to do if
Possible Duplicate: XmlSerializer: remove unnecessary xsi and xsd namespaces I'm generating some XML using
Possible Duplicate: Java: generating random number in a range I want to generate a
Possible Duplicate: Generating all Possible Combinations I'm trying to do a little algorithm in
Possible Duplicate: Generating all Possible Combinations Is there a good LINQ way to do
Possible Duplicate: Java: generating random number in a range How do I generate a
Possible Duplicate: Developing for Android in Eclipse: R.java not generating I cleaned my project
Possible Duplicate: Generating random number in a range with Java My code is generating
Possible Duplicate: Java: generating random number in a range I want to generate random
Possible Duplicate: Developing for Android in Eclipse: R.java not generating I have imported a

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.