quick attempt:

      3 {(⍵⍴⍨≢⍵)⊂⍨(≢⍵)↑⍺/⍵} 1 2 3 4 5 6 7
┏→━━━━━━━━━━━━━━━━━━┓
┃┏→━━━━┓ ┏→━━━━┓ ┏→┓┃
┃┃1 2 3┃ ┃4 5 6┃ ┃7┃┃
┃┗━━━━━┛ ┗━━━━━┛ ┗━┛┃
┗∊━━━━━━━━━━━━━━━━━━┛


On Sat, Apr 11, 2020 at 9:02 PM Otto Diesenbacher-Reinmüller <
ok...@diesenbacher.net> wrote:

> Hi APLers!
>
> as I had a look into the archives, it seems ok, to post non bugs and
> other topics not closely related to gnu-apl, but APL in general (for
> sure, utilizing gnu-apl)? If my following post is offtopic please
> excuse, and please let me know, where would be right place to discuss.
>
> So - i am quite new to APL, my road to APL? Some weeks ago, being a
> hobbyist/partly professional Common Lisper, I stumpled upon April
> (https://github.com/phantomics/april) and was fascinated by
> APL. Always hungry for /something/ to get rid of Excel, I am starting
> to explore the world of arrays ;).
>
> Having browsed through "Mastering Dyalog APL"(Legrand) and "APL_ The
> Language and Its Usage"(Polivka/Pakin), to get some experience, I am
> trying to solve (the easy parts) of the APL Dyalog Problem Solving
> Competition (https://www.dyalog.com/student-competition.htm).
>
> I would like to share my experience, discuss the obstacles I
> encounter, and especially get some advice/hints from you, the
> experienced APLers! Perhaps this will lead to some blog-posts...
>
> Let's start with the first one:
>
> 1 chunk monkey
> (
> https://www.dyalog.com/uploads/files/student_competition/2019_problems_phase1.pdf
> )
>
> "Write a function that, given a scalar or vector as the right argument
> and a positive (>0)integer chunk size n as the left argument, breaks
> the array's items up into chunks of sizen. If the number of elements
> in the array is not evenly divisible by n, then the last chunkwill
> have fewer than n elements. Hint: The partitioned enclose function ⊂
> could be helpful for this problem."(from the exercise)
>
> hmmm, as in the exercise stated, dyadic ⊂ (partition) is to be used.
> So the real challenge is to generate the correct vector as left
> argument for ⊂, right?
>
>
> ⍝ first try:
> ∇ z← size chunkmonkey1 a
>   z←((⍴a)↑(size/⍳⍴a)) ⊂ a
> ∇
> ⍝ BUT
> ⍝ - doesn't work with a scalar as asked
> ⍝ - ((⍴a)↑(size/⍳⍴a)) seems inefficient, as we make a to big
> ⍝   vector and cut it down afterwards... Is this a common/fine
> ⍝   pattern?
>
>
> ⍝ second try:
> ∇ z← size chunkmonkey2 a
>   →((0=≢⍴a)∧1=≢a)/skalar        ⍝ matches a skalar, but not ''
>   z←((≢a)↑(size/⍳≢a))⊂a         ⍝ ≢ or ⍴ in this case?
>   →0
> skalar:
>   z←a
> ∇
>
> ⍝ correct, but feels clumsy...
> ⍝ - ≢ seems more acurately than ⍴ in this case?
> ⍝ - should be doable without jump?
> ⍝ - still the inefficient vector
>
> Final thoughts for now:
>
> What I learned/understood with this exercise: / is not only reduce
> (operator), but also dyadic functions filter and especially expand
> (not all APL-variants?).
>
> Checking for types is not easy. 0=⍴N is a scalar. Howto check for a
> string?
>
> br & and many thanks for any hints, Otto
>
> --
> Dipl. Ing. (FH) Otto Diesenbacher-Reinmüller
> diesenbacher.net
> Salzburg, Österreich
>
>

Reply via email to