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

  • Home
  • SEARCH
  • 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 180139
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T14:31:59+00:00 2026-05-11T14:31:59+00:00

I would like to write a script that takes one argument that might look

  • 0

I would like to write a script that takes one argument that might look like this:

abc(ag)de* 

a, b, c are literal characters.

(ag) means ‘an ‘a’ or a ‘g”.

* means any one letter or number.

I want the script to create an Array of all the possible strings the input could represent. (The purpose is to check if they’re available domain names.)

The input could also be something like abc(ag)de(mnlop) where there are more than on character class.

Seems like the first task is to split it into an Array or Arrays, so the first example would be…

[   ['a'],   ['b'],   ['c'],   ['a', 'g'],   ['d'],   ['e'],   [     'a', 'b', 'c', 'd', 'e', 'f', 'g',     # etc...   ] ] 

This is where I get stuck. I don’t know how to split it up into pieces like that.

Any suggestions on how to approach it?

  • 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. 2026-05-11T14:31:59+00:00Added an answer on May 11, 2026 at 2:31 pm

    Here’s a pretty compact solution. It’s in no way optimized for performance which puts some constraints on the patterns you supply e.g. too many wildcards is probably not the best idea.

    Here’s the code

    input1 = 'abc(ag)de*' input2 = 'abc(ag)de(mnlop)'  class Array   def append_suffixes!(suffixes)     self.replace suffixes.map { |a| self.map { |p| p + a }}.flatten   end end  def generate_combinations(pattern)   combinations = ['']   pattern.scan(/\(([^)]+)\)|(\*)|(\w+)/) do |group,wildcard,other|     new_suffixes = case       when group    : group.split('')       when wildcard : [*'a'..'z']       when other    : other       else raise 'Unknown match!'     end     combinations.append_suffixes! new_suffixes   end   combinations end  p generate_combinations(input1) p generate_combinations(input2) p generate_combinations('**').size 

    The output from running the code above is (slightly edited):

    ['abcadea', 'abcgdea', 'abcadeb', 'abcgdeb', 'abcadec',   'abcgdec', 'abcaded', 'abcgded', 'abcadee', 'abcgdee',   'abcadef', 'abcgdef', 'abcadeg', 'abcgdeg', 'abcadeh',   'abcgdeh', 'abcadei', 'abcgdei', 'abcadej', 'abcgdej',   'abcadek', 'abcgdek', 'abcadel', 'abcgdel', 'abcadem',   'abcgdem', 'abcaden', 'abcgden', 'abcadeo', 'abcgdeo',   'abcadep', 'abcgdep', 'abcadeq', 'abcgdeq', 'abcader',   'abcgder', 'abcades', 'abcgdes', 'abcadet', 'abcgdet',   'abcadeu', 'abcgdeu', 'abcadev', 'abcgdev', 'abcadew',   'abcgdew', 'abcadex', 'abcgdex', 'abcadey', 'abcgdey',   'abcadez', 'abcgdez']  ['abcadem', 'abcgdem', 'abcaden', 'abcgden', 'abcadel',   'abcgdel', 'abcadeo', 'abcgdeo', 'abcadep', 'abcgdep']  676 # The number of two letter words i.e. 26*26 

    Please feel free to ask if you have any questions about the code above.

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

Sidebar

Ask A Question

Stats

  • Questions 77k
  • Answers 77k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • added an answer Apparently not: C:\temp\Tim>type 1.fs 2.fs 1.fs #light module Module let… May 11, 2026 at 3:36 pm
  • added an answer I used Rational RequisitePro and SoDA some time ago, it… May 11, 2026 at 3:36 pm
  • added an answer You don't say what the problem is. Is it performance?… May 11, 2026 at 3:36 pm

Related Questions

I maintain a number of load balanced web servers running Windows Server 2003. Today
Is there a idiomatic way of removing elements from PATH-like shell variables? That is
I am interested in seeing if I can improve the way we use NUnit
I'm trying to write a piece of code that will do the following: Take

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

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.