[Tutor] stopping a loop [cross product instead of nested loops]
Julieta Rangel
julieta_rangel@hotmail.com
Sun, 06 May 2001 20:06:27 -0500
I've been playing with the cross product definition you gave me. It makes a
lot of sense, and I'm sure it will make it a lot easier for me to prove
associativity; however, I'm doing something wrong because when I run it, I
don't get the result I thought I would. Would you take a look and tell me
what I'm doing wrong?
def cross(set1,set2):
resulting_set = []
for s1 in set1:
for s2 in set2:
resulting_set.append( (s1, s2) )
return resulting_set
set = ['e','a','b', 'ab']
print set
s = cross(set,cross(set,set))
print s
When I run it, I get the following:
['e', 'a', 'b', 'ab']
[('e', ('e', 'e'))] #Shouldn't I get 64 pairs here instead of one?
I thought that a loop would do the trick, but I couldn't figure out how to
do it. Can you help? I want to get the entire 64 pairs on my printout.
Julieta
>From: Daniel Yoo <dyoo@hkn.eecs.berkeley.edu>
>To: Sheila King <sheila@thinkspot.net>
>CC: Julieta Rangel <julieta_rangel@hotmail.com>, tutor@python.org
>Subject: Re: [Tutor] stopping a loop [cross product instead of nested
>loops]
>Date: Sun, 6 May 2001 02:10:20 -0700 (PDT)
>
>On Sat, 5 May 2001, Sheila King wrote:
>
> > On Sat, 05 May 2001 20:24:52 -0500, "Julieta Rangel"
><julieta_rangel@hotmail.com>
> > wrote about RE: [Tutor] stopping a loop:
> >
> > :Are you implying a tripple nested loop? meaning
> > :for x in set:
> > : for y in set:
> > : for z in set:
> > : if ['x',('y','z')] == [('x','y'),'z']:
> > : return associativity holds
> > :
> > :Is this what you mean? If I give the computer those commands, will it
>look
> > :for the definition on my dictionary? You see, I'm not sure how I'm
>supposed
> > :to tell the computer to look in the dictionary for these values and
>compare
> > :them. Any more hints, ideas, suggestions, comments, questions?
> > :
> > :Julieta
> >
> > I'm not sure if Tim was implying a triply-nested loop, or not. It
>sounded kind of
> > like it to me, too. However, a double-nested loop will do fine.
> >
> > The key is, you need to use your dictionary to look up the values of the
>operations.
> > That is the key. That is why you built the dictionary in the first
>place.
>
>
>You might find the following definition useful: it's a way of producing
>the "cross" product of two lists:
>
>###
>def cross(set1, set2):
> resulting_set = []
> for s1 in set1:
> for s2 in set2:
> resulting_set.append( (s1, s2) )
> return resulting_set
>###
>
>
>One reason why the cross product is so useful is because, given any two
>lists, it can give back to us all possible pairs of those two lists, all
>in a nice list:
>
>###
> >>> cross([1, 2, 3, 4], [1, 2, 3, 4])
>[(1, 1), (1, 2), (1, 3), (1, 4), (2, 1), (2, 2), (2, 3), (2, 4), (3, 1),
>(3, 2), (3, 3), (3, 4), (4, 1), (4, 2), (4, 3), (4, 4)]
>###
>
>Or, more evocatively:
>
>###
> >>> numbers = ['1', '2']
> >>> cross(numbers, cross(numbers, numbers))
>[('1', ('1', '1')), ('1', ('1', '2')), ('1', ('2', '1')),
> ('1', ('2', '2')), ('2', ('1', '1')), ('2', ('1', '2')),
> ('2', ('2', '1')), ('2', ('2', '2'))]
>###
>
>By using the function above, you might not even need any nested loops in
>your own code.
>
>
>Hope this helps!
>
_________________________________________________________________
Get your FREE download of MSN Explorer at http://explorer.msn.com