[#33161] Call/CC and Ruby iterators. — olczyk@... (Thaddeus L Olczyk)

Reading about call/cc in Scheme I get the impression that it is very

11 messages 2002/02/05

[#33242] favicon.ico — Dave Thomas <Dave@...>

19 messages 2002/02/06
[#33256] Re: favicon.ico — Leon Torres <leon@...> 2002/02/06

[#33435] Reg: tiny contest: who's faster? (add_a_gram) — grady@... (Steven Grady)

> My current solution works correctly with various inputs.

17 messages 2002/02/08

[#33500] Ruby Embedded Documentation — William Djaja Tjokroaminata <billtj@...>

Hi,

24 messages 2002/02/10
[#33502] Re: Ruby Embedded Documentation — "Lyle Johnson" <ljohnson@...> 2002/02/10

> Now, I am using Ruby on Linux, and I have downloaded Ruby version

[#33615] Name resolution in Ruby — stern@... (Alan Stern)

I've been struggling to understand how name resolution is supposed to

16 messages 2002/02/11

[#33617] choice of HTML templating system — Paul Brannan <paul@...>

I am not a web developer, nor do I pretend to be one.

23 messages 2002/02/11

[#33619] make first letter lowercase — sebi@... (sebi)

hello,

20 messages 2002/02/11
[#33620] Re: [newbie] make first letter lowercase — Tobias Reif <tobiasreif@...> 2002/02/11

sebi wrote:

[#33624] Re: [newbie] make first letter lowercase — "Jeff 'japhy' Pinyan" <jeffp@...> 2002/02/11

On Feb 11, Tobias Reif said:

[#33632] Re: [newbie] make first letter lowercase — Mathieu Bouchard <matju@...> 2002/02/12

[#33731] simple XML parsing (greedy / non-greedy — Ron Jeffries <ronjeffries@...>

Suppose I had this text

14 messages 2002/02/13

[#33743] qualms about respond_to? idiom — David Alan Black <dblack@...>

Hi --

28 messages 2002/02/13
[#33751] Re: qualms about respond_to? idiom — Dave Thomas <Dave@...> 2002/02/13

David Alan Black <dblack@candle.superlink.net> writes:

[#33754] Re: qualms about respond_to? idiom — David Alan Black <dblack@...> 2002/02/13

Hi --

[#33848] "Powered by Ruby" banner — Yuri Leikind <YuriLeikind@...>

Hello Ruby folks,

78 messages 2002/02/14
[#33909] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/14

On Thu, 14 Feb 2002, Yuri Leikind wrote:

[#33916] RE: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

A modest submission:

[#33929] Re: "Powered by Ruby" banner — yet another bill smith <bigbill.smith@...> 2002/02/15

Kent Dahl wrote:

[#33932] OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 5:54 AM, "yet another bill smith" <bigbill.smith@verizon.net>

[#33933] RE: OT Netscape 4.x? was Re: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

i just don't understand why it didn't show up! dhtml/javascript, ok, but a

[#33937] Re: OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 7:16 AM, "Jack Dempsey" <dempsejn@georgetown.edu> wrote:

[#33989] Re: OT OmniWeb [was: Netscape 4.x?] — Sean Russell <ser@...> 2002/02/16

Chris Gehlker wrote:

[#33991] Re: OT OmniWeb [was: Netscape 4.x?] — Rob Partington <rjp@...> 2002/02/16

In message <3c6e5e01_1@spamkiller.newsgroups.com>,

[#33993] Re: OT OmniWeb [was: Netscape 4.x?] — Thomas Hurst <tom.hurst@...> 2002/02/16

* Rob Partington (rjp@browser.org) wrote:

[#33925] Re: "Powered by Ruby" banner — Martin Maciaszek <mmaciaszek@...> 2002/02/15

In article <3C6CFCCA.5AD5CA67@scnsoft.com>, Yuri Leikind wrote:

[#33956] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/15

On Fri, 15 Feb 2002, Martin Maciaszek wrote:

[#33851] Ruby and .NET — Patrik Sundberg <ps@...>

I have been reading a bit about .NET for the last couple of days and must say

53 messages 2002/02/14

[#34024] Compiled companion language for Ruby? — Erik Terpstra <erik@...>

Hmmm, seems that my previous post was in a different thread, I'll try

12 messages 2002/02/16

[#34036] The GUI Returns — "Horacio Lopez" <vruz@...>

Hello all,

33 messages 2002/02/17

[#34162] Epic4/Ruby — Thomas Hurst <tom.hurst@...>

Rejoice, for you no longer have to put up with that evil excuse for a

34 messages 2002/02/18

[#34185] Operator overloading and multiple arguments — ptkwt@...1.aracnet.com (Phil Tomson)

I'm trying to overload the '<=' operator in a class in order to use it for

10 messages 2002/02/18

[#34217] Ruby for web development — beripome@... (Billy)

Hi all,

21 messages 2002/02/19

[#34350] FAQ for comp.lang.ruby — "Hal E. Fulton" <hal9000@...>

RUBY NEWSGROUP FAQ -- Welcome to comp.lang.ruby! (Revised 2001-2-18)

15 messages 2002/02/20

[#34375] Setting the Ruby continued — <jostein.berntsen@...>

Hi,

24 messages 2002/02/20
[#34384] Re: Setting the Ruby continued — Paulo Schreiner <paulo@...> 2002/02/20

Also VERY important:

[#34467] recursive require — Ron Jeffries <ronjeffries@...>

I'm having a really odd thing happen with two files that mutually

18 messages 2002/02/21

[#34503] special characters — Tobias Reif <tobiasreif@...>

Hi all,

13 messages 2002/02/22

[#34517] Windows Installer Ruby 166-0 available — Andrew Hunt <andy@...>

16 messages 2002/02/22

[#34597] rdoc/xml questions — Dave Thomas <Dave@...>

24 messages 2002/02/23

[#34631] Object/Memory Management — "Sean O'Dell" <sean@...>

I'm new to Ruby and the community here (I've been learning Ruby for a grand

44 messages 2002/02/23

[#34682] duplicate method name — Ron Jeffries <ronjeffries@...>

I just found a case in a test file where i had two tests of the same

16 messages 2002/02/24
[#34687] Re: duplicate method name — s@... (Stefan Schmiedl) 2002/02/24

Hi Ron.

[#34791] Style Question — Ron Jeffries <ronjeffries@...>

So I'm building this set theory library. The "only" object is supposed

13 messages 2002/02/25

[#34912] RCR?: parallel to until: as_soon_as — Tobias Reif <tobiasreif@...>

Hi,

18 messages 2002/02/26

[#34972] OT A Question on work styles — Chris Gehlker <gehlker@...>

As a Mac baby I just had to step through ruby in GDB *from the command line*

20 messages 2002/02/28

[#35015] Time Comparison — "Sean O'Dell" <sean@...>

I am using the time object to compare times between two files and I'm

21 messages 2002/02/28

Re: Reg: tiny contest: who's faster? (add_a_gram)

From: David Alan Black <dblack@...>
Date: 2002-02-09 15:13:44 UTC
List: ruby-talk #33480
Hi --

On Sat, 9 Feb 2002, Dave Thomas wrote:

> "Pit Capitain" <pit@capitain.de> writes:
>
> > * Should it only work with the given or with any word list?
> > * Should it only print the last word or the whole sequence?
>
> The challenge asks for the longest word, not the chain. However,
> adding reporting for the whole chain barely affects the run time. I've
> attached the new version.
>
> However I do think it should work with any list.
>
> > * Is it allowed to use C extensions or has it to be pure Ruby?
>
> Pure Ruby, I'd say.

I agree, though I'm happy to see the strbsrt extension getting some
publicity :-)

Attached is a RubyUnit-ified version of this challenge.  It's probably
sketchier than it should be, in terms of its tests, but feel free
to use it and change it if helpful.

I've included, as the implementation of class AAGFinder, a slightly
hacked version of Dave's solution.  If you want to start again (i.e.,
unit-test your own solution), just reimplement AAGFinder and make
sure that it has a #find_longest method that passes the test.

Code follows sig....


David

-- 
David Alan Black
home: dblack@candle.superlink.net
work: blackdav@shu.edu
Web:  http://pirate.shu.edu/~blackdav


#!/usr/local/bin/ruby -w
# addagram.rb

require "runit/testcase"
require "runit/cui/testrunner"
require "runit/testsuite"

class AAGFinder

## BEGIN adapation from Dave Thomas ##

  def initialize(fh)
    @known_failures = {}
    @words = {}
    @words_of_length = []
    @max_length = 0

    fh.read.split.each do |word|
      @words[w = word.unpack("c*").sort.pack("c*")] = word
      len = word.length
      if len > 11
	unless @words_of_length[len]
	  @words_of_length[len] = []
	  @max_length = len if len > @max_length
	end
	@words_of_length[len] << word
      end
    end
  end

  def test_word(the_word, res)
    res << the_word
    return res if the_word.length == 3

    unless @known_failures[the_word]
      word = the_word.dup
      ch = word.slice!(0)
      len = word.length
      (len+1).times do |i|
      return res if @words[word] && test_word(word, res)
      word[i], ch = ch, word[i] if i < len
      end
      @known_failures[the_word] = true
    end
    res.pop
    false
  end

  def find_longest
    @max_length.downto(3) do |l|
      (@words_of_length[l] || []).each do |word|
      res = []
	if test_word(word.unpack("c*").sort.pack("c*"), res)
	  return res.map {|r| @words[r]}.join ","
	end
      end
    end
    nil
  end

## END adaptation from Dave Thomas

end

class AAGTest < RUNIT::TestCase
  def setup
    @af = AAGFinder.new(DATA)
  end

  def test_longest
    aag = @af.find_longest
    assert_equal(aag, %w{alliterations alliteration retaliation
                         alteration,rationale relation retinal
                         rental later tear tar} .join ",")
  end
end

RUNIT::CUI::TestRunner.run(AAGTest.suite)

__END__
accelerating activates adsorbs aggrieves alliteration alliterations
allocators alteration amplifies answerers applied armies assertions
attitude avoid ball bask befall bespeak birthright blocs bookie
brambles broadcasters bumptiousness cached capitalizing catheter
chanter chirped clapping clumsy colonially compatibles concubine
conscript contour corkscrew courtyard crisis curious daunted dedicates
demandingly deserter diagramming directory disjunction distributions
doubter drunks economic elucidate enders envelopes evades exempted
extension fanatics ferried firsts flourishes forgeries frequent gadget
genuinely goaded gratitude guile harboring heifer hitchhiker hounded
ideas implants incompletely inexorably inlet integrate intimated
irrigate judgment knobs later lavishly lewdly litter lowest mallard
masterpiece memorandum midwives mist mooning multiprocessor nauseum
nobly numberer offensiveness ordering overflows palmed parties peers
personalized pierced plasters polloi pourer preparations probings
prophesy publisher quantile railroads rationale reading recognized
referenced rejoiced relation rental reparation resets retaliation
retinal retransmits right roughly sailors scarce seahorse sensed
shapers showy singing sleeper snatched sooner speeded spur statically
stomach structure substantive superbly swearer tail tar tear televise
thermometer timetable towering treasure tuned unconventional unison
unwitting varnishes vineyard wanting whales wised writhes

In This Thread