My attempt (not keen on the redo loop):

#! perl -slw use strict; use threads stack_size => 4096; use threads::Q; use Scalar::Util qw[ dualvar ]; use constant { TRUE => dualvar( 1, 'true' ), FALSE => dualvar( 0, 'fal +se' ) }; use enum qw[ LEFT RIGHT ]; sub fringe { my $tree = shift; my $Q = threads::Q->new( 1 ); my $scan; $scan = sub{ my $t = shift; !ref( $t ) ? $Q->nq( $t ) : ( &$scan( $t->[LEFT] ), &$scan( $t +->[RIGHT] ) ); }; async{ $scan->( $tree ); $Q->nq( undef ); }->detach; return sub{ $Q->dq; }; } sub sameFringe { my $i1 = fringe( shift ); my $i2 = fringe( shift ); { no warnings 'uninitialized'; ( my $v1 = &$i1 ) == ( my $v2 = &$i2 ) or return FALSE; redo if defined( $v1 // $v2 ); } return TRUE; } my $a = [ 1, [ 2, [ 3, [ 4, 5 ] ] ] ]; my $b = [ 1, [ [ 2, 3 ], [ 4, 5 ] ] ]; my $c = [ [ [ [ 1, 2 ], 3 ], 4 ], 5 ]; print sameFringe( $a, $a ); print sameFringe( $a, $b ); print sameFringe( $a, $c ); my $x = [ 1, [ 2, [ 3, [ 4, [ 5, 6 ] ] ] ] ]; my $y = [ 0, [ [ 2, 3 ], [ 4, 5 ] ] ]; my $z = [ 1, [ 2, [ [ 4, 3 ], 5 ] ] ]; print sameFringe( $a, $x ); print sameFringe( $a, $y ); print sameFringe( $a, $z ); __END__ C:\test>lazyTree.pl true true true false false false

With the rise and rise of 'Social' network sites: 'Computers are making people easier to use everyday'
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

In reply to Re: Challenge: Perl 5: lazy sameFringe()? by BrowserUk
in thread Challenge: Perl 5: lazy sameFringe()? by BrowserUk

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.