You could use
@G1_Hash{ qw/HO KO.../ } = ();
To make the assignment one step, but this won't be a significant change when comparing to a more efficient loop. You could make the loop more efficient by making your test cases ordered by probability, and then skip to the next line without testing it again with
push (@G1_out, $input), next if exists $G1_Hash{$prefix}
The exists function is just to fix my prior laziness - assiging an empty list to the hash slice - which will result in the values being undefined. I don't know, but perhaps not testing for truth on the value may save a bit more...

Due to the fact that the loop will probably be performed many times over, a little change can be multiplied by the number of times a step is saved.

-nuffin
zz zZ Z Z #!perl

In reply to Re: Efficient Grouping by nothingmuch
in thread Efficient Grouping by meetraz

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.