From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: ** X-Spam-Status: No, score=2.2 required=5.0 tests=BAYES_00,INVALID_MSGID, PDS_OTHER_BAD_TLD,REPLYTO_WITHOUT_TO_CC autolearn=no autolearn_force=no version=3.4.4 X-Google-Language: ENGLISH,ASCII-7-bit X-Google-Thread: f43e6,9a0ff0bffdf63657 X-Google-Attributes: gidf43e6,public X-Google-Thread: fac41,9a0ff0bffdf63657 X-Google-Attributes: gidfac41,public X-Google-Thread: 103376,4b06f8f15f01a568 X-Google-Attributes: gid103376,public X-Google-Thread: 1108a1,9a0ff0bffdf63657 X-Google-Attributes: gid1108a1,public From: Loryn Jenkins Subject: Re: Software landmines (loops) Date: 1998/09/01 Message-ID: <35EBBFAF.DE38C061@s054.aone.net.au>#1/1 X-Deja-AN: 386728668 Content-Transfer-Encoding: 7bit References: <902934874.2099.0.nnrp-10.c246a717@news.demon.co.uk> <6r1glm$bvh$1@nnrp1.dejanews.com> <6r9f8h$jtm$1@nnrp1.dejanews.com> <6renh8$ga7$1@nnrp1.dejanews.com> <6rf59b$2ud$1@nnrp1.dejanews.com> <6rfra4$rul$1@nnrp1.dejanews.com> <35DBDD24.D003404D@calfp.co.uk> <6sbuod$fra$1@hirame.wwa.com> <35f51e53.48044143@ <904556531.666222@miso.it.uq.edu.au> <35EAEC47.164424A7@s054.aone.net.au> X-Priority: 3 (Normal) Content-Type: text/plain; charset=us-ascii X-Trace: news.mel.aone.net.au 904642575 18890 203.102.238.30 (1 Sep 1998 09:36:15 GMT) Organization: TekRite Pty Ltd Mime-Version: 1.0 Reply-To: loryn@acm.org NNTP-Posting-Date: 1 Sep 1998 09:36:15 GMT Newsgroups: comp.lang.eiffel,comp.object,comp.software-eng,comp.lang.ada Date: 1998-09-01T09:36:15+00:00 List-Id: Matthew Heaney wrote: > > Loryn Jenkins writes: > > > How is this more complicated? > > > > equal (l,r: LIST): BOOLEAN is > > require > > l.count = r.count > > do > > Result := l.first /= r.first > > if Result then > > from > > l.start; r.start > > until > > not Result or l.off > > loop > > Result := l.item /= r.item > > l.forth; r.forth > > end > > end > > end > > There are a few things I don't like about this: > > 1) You have to test a flag every iteration of the loop. That adds (a > marginal amount of) inefficiency. Oh well. I can live with that. (Unless my profiler tells me it is in a hot spot ... which doesn't happen too often.) > 2) The loop predicate has 4 possible values. The original example had > only 2. And you had two exit points, and I have one. (Probably because I'm not familiar with your style) I actually have to work a bit harder than reading my version. > 3) There's more nesting. Sorry, I don't see that. You have one for loop and an if statement. I have one if statement and a loop. Seems the same amount of nesting to me. > So yes, I feel the above implementation is more complex than the > original implementation that used muliple returns. Oh well, we'll have to agree to disagree then. > That's what the check L.Top /= R.Top means: if the number of items is > different, then you know immediately that the stacks can't be equal. > When you reach the loop, you know the stack depths are the same. Ah! For some reason, I thought you were testing the first item on the stack. So, my amended code, to match your semantics is thus: equal (l,r: LIST): BOOLEAN is require l /= Void and r /= Void do Result := l.count /= r.count if Result then from l.start; r.start until not Result or l.off loop Result := l.item /= r.item l.forth; r.forth end end end > The way I look at this problem, is that it's like searching for a > specific house on an unfamiliar block. As you're driving, when you find > the house, you stop immediately and declare success. You don't have to > drive to the end of the block, and then say where the house was. Yeah, yeah. Same here, given the amended code. Loryn Jenkins PS: I really would agree with you if the only counter examples were Tim McDermott's and Jim Cochrane's ones.