F# 入门(十一):链表与数组

链表和数组都是数据的集合。

F#的链表是线性列表的一种,单方向链表,它是基本数据结构之一,一种携带指向下一个元素的指针的数据结构。链表中的元素必须是同类型的数据类型。

而数组与链表很相似,但它可以使用数组索引来访问到数组中的某个元素。同时,它的元素也必须全部是同类型的数据类型。

 

链表的写法是用[]来表示,同时元素用";"来分隔。当然不用";"分隔情况也是有的

请看下面的一些例子:

> [];; // 空链表

val it :'a list = []

> [1;2;3];; // 普通链表,用";"来分隔元素

val it :int list = [1; 2; 3]

// 用换行来分隔元素

> leta = [ "Monday"

          "Tuesday"

          "Wednesday"];;

val a :string list = ["Monday"; "Tuesday"; "Wednesday"]

>

 

链表可以使用::与@符号进行链接。

::是将元素与链表进行链接,::的左侧是元素,右侧是链表,同时两侧必须是同类型数据。

>1::[2;3];;

val it :int list = [1; 2; 3]

>1::2::3::[4];;

val it :int list = [1; 2; 3; 4]

 

@是将两个链表进行连接。

>[1;2]@[3;4;5];;

val it :int list = [1; 2; 3; 4; 5]

>["a";"b"]@["c";"d";"e"];;

val it :string list = ["a"; "b"; "c"; "d";"e"]

>

 

链表的简便写法:

> [1..10];; // 默认增量为1

val it :int list = [1; 2; 3; 4; 5; 6; 7; 8; 9; 10]

> [1..2..10];; // 增量为2

val it :int list = [1; 3; 5; 7; 9]

> [1..3..10];; // 增量为3

val it :int list = [1; 4; 7; 10]

 

数组的写法是用[||],同时元素用";"来分隔。当然不用";"分隔情况也是有的

> [||];; // 空数组

val it : 'a [] =[||]

> [|1;2;3|];; // 普通数组,用";"来分隔元素

val it : int [] =[|1; 2; 3|]

// 用换行来分隔元素

>  let a = [|"Monday"

           "Tuesday"

           "Wednesday"|];;

val a : string [] =[|"Monday"; "Tuesday"; "Wednesday"|]

>

 

使用数组索引可以访问数组中的元素,第一个元素索引为0。

>  let a = [|"Monday"

           "Tuesday"

           "Wednesday"|];;

 

val a :string [] = [|"Monday"; "Tuesday"; "Wednesday"|]

> a.[0];;

val it :string = "Monday"

>

数组的简略写法:

> [|1 .. 10|];; // 默认增量为1

val it :int [] = [|1; 2; 3; 4; 5; 6; 7; 8; 9; 10|]

> [|1 .. 2 .. 10|];; // 增量为2

val it :int [] = [|1; 3; 5; 7; 9|]

> [|1 .. 3 .. 10|];; // 增量为3

val it :int [] = [|1; 4; 7; 10|]

posted @ 2012-02-27 10:46  tryfsharp  阅读(1412)  评论(3编辑  收藏  举报