From: Brian Hurt <brian.hurt@qlogic.com>
To: Ryan Bastic <rbastic@gis.net>
Cc: <caml-list@inria.fr>
Subject: Re: [Caml-list] Clarification of original post [still having problems]
Date: Tue, 22 Apr 2003 14:46:26 -0500 (CDT) [thread overview]
Message-ID: <Pine.LNX.4.33.0304221437460.2225-100000@eagle.ancor.com> (raw)
In-Reply-To: <3ea3174b.37b7.27531@gis.net>
On Sun, 20 Apr 2003, Ryan Bastic wrote:
>
> Can anyone take some time and help a struggling newbie out? :-(
>
> This stuff is still failing to parse right for my brain.
>
> ----- Original Message Follows -----
> > Hello all,
> > A few weeks ago I posted a message asking how to create a program in
> > OCaml to shuffle vector of strings into an array of arrays. Had some
> > problems understanding how to do it in Ocaml properly, and a kind soul
> > posted a very elegant solution to the problem :-) unfortunately, i
> > still can't understand some things from it.
> >
> > What follows is some code with comments on how it is expected to be
> > used, and also
> > where my confusion in the semantics of the code lay.
> >
> > (* Return first 'n' from input and the rest. *)
> > let firstN n input =
> > let nInput = Array.length input in
> > if n >= nInput
> > then (input, [||])
> > else (Array.sub input 0 n, Array.sub input n (nInput - n))
> >
> > let group n input =
> > let rec group' n input =
> > if Array.length input = 0 then []
> > else
> > let (front, rest) = firstN n input in
> > (* the next line confuses me. i'm aware of :: being a list
> > concatenation operator, but in this case, shouldn't group 'n rest be
> > returning an array, because that's what firstN returns. I've
> experimented in
> > the REPL and had no luck in figuring it out. *)
> > front :: group' n rest
> > in
> > Array.of_list (group' n input)
> >
>
> The specific problems that confuse me is that
>
> let rec group' ... in Array.of_list is all part of the same expression,
> so how does Ocaml
> let front :: group' n rest work?? firstN n input returns two arrays, and
> as far as my
> understanding goes, :: is a list concatenation operator. How then, does
> this work?
You can have lists of arrays just fine. Which is what this function
returns. Basically, it (recursively) calls group', which returns a list
of arrays. When the recursive call returns, it prepends front to the list
and returns the prepended-to list.
One trick I find myself doing a lot is to cut internal functions out into
global functions to check their type signatures. And given:
let rec group' n input =
if Array.length input = 0 then []
else
let (front, rest) = firstN n input in
front :: group' n rest
Ocaml returns the type:
val group' : int -> 'a array -> 'a array list = <fun>
Which means a function that takes two arguments, an int and an 'a array,
and returns a 'a array list. group' returns a list- so prepending an 'a
to the list makes perfect sense.
Does this help?
Brian
-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
next prev parent reply other threads:[~2003-04-22 19:39 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-04-20 21:55 Ryan Bastic
2003-04-22 19:46 ` Brian Hurt [this message]
2003-04-22 19:53 ` Karl Zilles
2003-04-22 21:12 Ryan Bastic
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Pine.LNX.4.33.0304221437460.2225-100000@eagle.ancor.com \
--to=brian.hurt@qlogic.com \
--cc=caml-list@inria.fr \
--cc=rbastic@gis.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox