[#395238] rubygem: ispunity (unite all your internet connections) — Arun Tomar <tomar.arun@...>

Dear friends,

12 messages 2012/05/01

[#395250] Overwriting one Ruby array or arrays with another — Craig Law <lists@...>

Hi

14 messages 2012/05/02

[#395258] array of strings - finding letter combinations — "Sebastjan H." <lists@...>

Hi All,

16 messages 2012/05/02

[#395357] Why Enumerator#next does not return more than one value? — Földes László <lists@...>

If I have an Enumerator which yields elements of a mathematical series

10 messages 2012/05/07

[#395373] How to use Data_Wrap_Struct to assign the DATA VALUE to an exsiting Ruby object? — Iñaki Baz Castillo <ibc@...>

Hi, my code receives an arbitrary klass name (provided by the user)

8 messages 2012/05/07

[#395429] passing via instance variable or regular () — sam jam <lists@...>

def first

10 messages 2012/05/10

[#395463] I'm looking for a Metaprogramming Project — Phil Stone <lists@...>

Hello,

19 messages 2012/05/11

[#395548] A million reasons why Encoding was a mistake — Marc Heiler <lists@...>

Newcomer wants to try Ruby.

15 messages 2012/05/15
[#395561] Re: A million reasons why Encoding was a mistake — Ryan Davis <ryand-ruby@...> 2012/05/15

[#395595] Re: A million reasons why Encoding was a mistake — Brian Candler <lists@...> 2012/05/16

I will add that the OP is not entirely alone in his opinion.

[#395551] How to ensure that a block runs entirely after other threads? (Thread.exclusive does not "work") — Iñaki Baz Castillo <ibc@...>

Hi, I expected that in the following example code, thread t1 would not

8 messages 2012/05/15

[#395575] GUI with ruby on windows — David Acosta <lists@...>

hello friends, i am a begginer and i have a litlle question, how can i

17 messages 2012/05/16

[#395604] what is going wrong here? — roob noob <lists@...>

Notice the initialization of both classes in each of the examples, if

20 messages 2012/05/16

[#395646] rb_gc_register_address() or rb_gc_mark()? — Iñaki Baz Castillo <ibc@...>

Hi, I've bad experiences with rb_gc_register_address(), it does never

16 messages 2012/05/17

[#395686] reading from and writing to a Unicode encoded file — "Sebastjan H." <lists@...>

Hi,

19 messages 2012/05/18
[#395694] Re: reading from and writing to a Unicode encoded file — Regis d'Aubarede <lists@...> 2012/05/18

Hello,

[#395697] Re: reading from and writing to a Unicode encoded file — "Sebastjan H." <lists@...> 2012/05/18

Regis d'Aubarede wrote in post #1061272:

[#395698] Re: reading from and writing to a Unicode encoded file — Regis d'Aubarede <lists@...> 2012/05/18

Sebastjan H. wrote in post #1061276:

[#395699] Re: reading from and writing to a Unicode encoded file — "Sebastjan H." <lists@...> 2012/05/18

Regis d'Aubarede wrote in post #1061277:

[#395750] Re: reading from and writing to a Unicode encoded file - issues when using Shoes — "Sebastjan H." <lists@...> 2012/05/21

Hi,

[#395754] Re: reading from and writing to a Unicode encoded file - issues when using Shoes — "Sebastjan H." <lists@...> 2012/05/21

Sebastjan H. wrote in post #1061483:

[#395740] ? Ruby through CGI and Rails — Shaun Lloyd <list@...>

Hi everybody,

22 messages 2012/05/21
[#395764] Re: Ruby through CGI and Rails — Brian Candler <lists@...> 2012/05/21

Shaun Lloyd wrote in post #1061455:

[#395786] Re: Ruby through CGI and Rails — Shaun Lloyd <list@...> 2012/05/22

On 22/05/12 03:37, Brian Candler wrote:

[#395838] Re: Ruby through CGI and Rails — Brian Candler <lists@...> 2012/05/23

Shaun Lloyd wrote in post #1061602:

[#395787] Changing self class from inside a method?? — David Madison <lists@...>

Let's start off with the assumption I want a method that allows an

10 messages 2012/05/22

[#395841] Memory-efficient set of Fixnums — George Dupre <lists@...>

Hi,

25 messages 2012/05/23

[#395883] looking for a ruby idiom : r=foo; return r if r — botp <botpena@...>

Hi All,

11 messages 2012/05/24

[#395966] Am I justified to use a global variable if it must be used in all scopes? — Phil Stone <lists@...>

Hello,

12 messages 2012/05/27

[#396010] does this leak more than the size of the string via timing side channels — rooby shoez <lists@...>

string1 = "string"

16 messages 2012/05/29

[#396038] Is it possible to avoid longjmp in exceptions, Thread#kill, exit(), signals? — Iñaki Baz Castillo <ibc@...>

Hi, my Ruby C extension runs a C loop (libuv) without GVL. At some

8 messages 2012/05/29

Re: Ruby Arrays (Pushing Array Inside the same array)

From: "Llelan D." <lists@...>
Date: 2012-05-17 00:56:54 UTC
List: ruby-talk #395624
The main problem here is the description of what is desired. A lot of
information has been left out. An analysis of the given input and output
arrays would seem to suggest the algorithm:

c << a[i] and d << b[i] if
       a[i] is not a multiple of a[j] from any other element
    && b[i] != b[j]

The unanswered questions are
    Is there a pattern to the sequence of x values? Those given are
ascending multiples of 9.
    What is the relationship of b[i] to a[i]?

The following ruby implementation performs the above algorithm with no
assumption about the pattern or order of elements in array a, or the
relationship of b[i] to a[i].
--------------------------------------------------------------------
a, b, c, d =
    [9, 18, 27, 36, 45, 54, 63, 72, 81, 90, 99, 108, 117, 126],
    [1,  1,  2,  1,  1,  3,  4,  5,  2,  1,  1,   3,   6,   1],
    [],
    []

(a.count - 1).times {|i|
    (ai, bi) = a[i], b[i]
    ej = (a.count - 1).times
    loop do
        begin
            j = ej.next
            (aj, bj) = a[j], b[j]
            break if i != j and ai % aj == 0 and bi == bj
        rescue
            c << ai
            d << bi
            break
        end
    end
}
c << a[-1]
d << b[-1]

puts('c: ' + c.to_s)
puts('d: ' + d.to_s)
--------------------------------------------------------------------
Output:

c: [9, 27, 54, 63, 72, 117, 126]
d: [1, 2, 3, 4, 5, 6, 1]
--------------------------------------------------------------------

It may not be the most concise usage of the Ruby syntax, but it gets the
job done without generating any extra array copies, and terminates the
inner loop once a reason is found to not push the current (ai, bi) pair.

If more were known about the pattern of values in a, or the relationship
of b[i] to a[i], a more efficient implementation could be created.

You might find it more friendly to Ruby to change the input values from
two separate arrays with the same length to one array with 2-element
pairs as elements. [[9, 1], [18, 1]...]

I hope you find that of some help.

P.S. If anyone can create the same implementation with more concise Ruby
syntax without generating any extra interim arrays, I'd love to see it.

-- 
Posted via http://www.ruby-forum.com/.

In This Thread