[#389739] Ruby Challenge — teresa nuagen <unguyen90@...>

Here is a ruby challenge for all you computer science lovers out there,

22 messages 2011/11/05
[#389769] Re: Ruby Challenge — "Jonan S." <jonanscheffler@...> 2011/11/05

Totally unrelated to any husker computer science programs right? Like

[#389905] Re: Ruby Challenge — Stephen Ramsay <sramsay.unl@...> 2011/11/09

Jonan S. wrote in post #1030330:

[#389907] Re: Ruby Challenge — aseret nuagen <unguyen90@...> 2011/11/09

> You mean like the professor for the course? Because that would be me .

[#389915] Re: Ruby Challenge — Robert Klemme <shortcutter@...> 2011/11/09

On Wed, Nov 9, 2011 at 4:52 AM, aseret nuagen <unguyen90@aim.com> wrote:

[#389792] Tricky DSL, how to do it? — Intransition <transfire@...>

I'd want to write a DSL such that a surface method_missing catches

18 messages 2011/11/06

[#389858] Compiling Ruby Inline C code - resolving errors — Martin Hansen <mail@...>

I am trying to get this Ruby inline C code http://pastie.org/2825882 to

12 messages 2011/11/08

[#389928] Forming a Ruby meetup group... — "Darryl L. Pierce" <mcpierce@...>

Where I work we have a local Ruby group that used to meet up, until the

12 messages 2011/11/09

[#389950] The faster way to read files — "Noé Alejandro" <casanejo@...>

Does anybody know which is the fastest way to read a file? Lets say

18 messages 2011/11/09

[#390064] referring to version numbers in a gem — Chad Perrin <code@...>

How do I specify and access a gem's version number within the code of the

28 messages 2011/11/11

[#390238] RVM problem, plz help — Misha Ognev <b1368810@...>

Hi, I have this problem:

15 messages 2011/11/16

[#390308] any command line tools for querying yaml files — Rahul Kumar <sentinel1879@...>

(Sorry, this is not exactly a ruby question).

11 messages 2011/11/18

[#390338] Newbie - cmd question — Otto Dydakt <ottodydakt@...>

I've literally JUST downloaded ruby from rubyinstaller.org.

21 messages 2011/11/19
[#390342] Re: Newbie - cmd question — Otto Dydakt <ottodydakt@...> 2011/11/19

OK thank you, I uninstalled & reinstalled, checking the three boxes at

[#390343] Re: Newbie - cmd question — "Ian M. Asaff" <ian.asaff@...> 2011/11/19

did you type "irb" first to bring up the ruby command prompt?

[#391154] Re: Newbie - cmd question — "Hussain A." <hahmad@...> 2011/12/12

Hi all,

[#391165] Re: Newbie - cmd question — Luis Lavena <luislavena@...> 2011/12/12

Hussain A. wrote in post #1036281:

[#390374] Principle of Best Principles — Intransition <transfire@...>

I seem to run into a couple of design issue a lot and I never know what is

16 messages 2011/11/20

[#390396] how to call Function argument into another ruby script. — hari mahesh <harismahesh@...>

Consider I have a ruby file called library.rb.

10 messages 2011/11/21

[#390496] How to make 1.9.2 my default version using RVM — Fily Salas <fs_tigre@...>

Hi,

25 messages 2011/11/24

[#390535] Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...>

Well, first of all, I'm new to Ruby, and to this forum. So, hello. :)

39 messages 2011/11/25
[#390580] Re: Is high-speed sorting impossible with Ruby? — Joao Pedrosa <joaopedrosa@...> 2011/11/27

Hi,

[#390593] Re: Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...> 2011/11/27

Joao Pedrosa wrote in post #1033884:

[#390600] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

A big gain can be had by disabling the garbage collector. Here is my best

[#390601] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

I've thrown various solutions up on github here:

[#390650] Loading a faulty ruby file - forcing this — Marc Heiler <shevegen@...>

Hi.

10 messages 2011/11/29

[#390689] Stupid question — James Gallagher <lollyproductions@...>

Hi everyone.

22 messages 2011/11/30

Re: Is high-speed sorting impossible with Ruby?

From: Robert Klemme <shortcutter@...>
Date: 2011-11-29 08:35:43 UTC
List: ruby-talk #390646
2011/11/29 Matthias W=E4chter <matthias@waechter.wiz.at>:
> On 29.11.2011 02:05, Josh Cheek wrote:
>>
>> 2011/11/28 Matthias W=E4chter<matthias@waechter.wiz.at>
>>
>>> A similar solution, at first glance only marginally different, is the
>>> following:
>>>
>>> =A0$stdin.gets
>>>>
>>>> puts $stdin.each_line.sort_by(&:to_**i)
>>>>
>>>
>>> Besides the fact that this solution is slower than yours, it uses a nea=
t
>>> little technique of Ruby 1.9, Enumerators.
>>
>>
>> $stdin is already enumerable, so each_line isn't necessary
>>
>> puts $stdin.drop(1).sort_by(&:to_i)
>
> Great one-liner, thanks!
>
> But in the context of my posting, it is not following the Enumerator
> principle. $stdin.drop(1) creates a large array on its output which I wan=
ted
> to avoid.

How do you avoid having an Array with all items when sorting?  If you
want to do that you need more advanced sorting algorithms (external
sorting) where not all the data is in main memory all the time.

> What we need is an enumeratoresque version of Enumerable#drop, which I ca=
ll
> drop_first. It will only consume on its input
>
>> class Enumerator
>> =A0def filter1(&blk)
>> =A0 =A0self.class.new do |y|
>> =A0 =A0 =A0each do |*input|
>> =A0 =A0 =A0 =A0y << blk.call(*input)
>> =A0 =A0 =A0end
>> =A0 =A0end
>> =A0end
>>
>> =A0def drop_first(n)
>> =A0 =A0self.class.new do |y|
>> =A0 =A0 =A0with_index do |input,idx|
>> =A0 =A0 =A0 =A0y << input if idx >=3D n
>> =A0 =A0 =A0end
>> =A0 =A0end
>> =A0end
>> end
>>
>> puts $stdin.to_enum(:each_line).drop_first(1).filter1(&:to_i).sort
>
> Performance-wise not better at all, but a nice excursion.

Why so complicated?  You can just do

module Enumerable
  def drop1(n)
    each_with_index {|x,i| yield x if i >=3D n}
  end
end

Or, also callable without a block:

module Enumerable
  def drop1(n)
    if block_given?
      each_with_index {|x,i| yield x if i >=3D n}
    else
      enum_for(:drop1, n)
    end
  end
end


irb(main):037:0> Source.new.drop1(2) {|i| printf "*block %2d\n", i}
before  0
after   0
before  1
after   1
before  2
*block  2
after   2
before  3
*block  3
after   3
before  4
*block  4
after   4
=3D> #<Source:0x102b4890>

But you can achieve the same memory complexity with standard means:

puts $stdin.drop(1).map!(&:to_i).sort!

Here #drop creates the Array once and all other operations work on that:

irb(main):054:0> a=3DArray.new(10){rand 20}
=3D> [14, 6, 6, 0, 14, 16, 19, 10, 14, 0]
irb(main):055:0> a.object_id
=3D> 135532690
irb(main):056:0> a.drop(1).tap {|o| p o.object_id}.map!(&:to_i).tap
{|o| p o.object_id}.sort!.tap {|o| p o.object_id}
134354700
134354700
134354700
=3D> [0, 0, 6, 6, 10, 14, 14, 16, 19]

Kind regards

robert

--=20
remember.guy do |as, often| as.you_can - without end
http://blog.rubybestpractices.com/

In This Thread