免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4376 | 回复: 8
打印 上一主题 下一主题

[其他] 问一些erlang的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-13 17:21 |只看该作者 |倒序浏览
函数式编程中,如erlang的列表,获取某个特定元素的值只能采用线性查找吗?

有无类似的键值?

论坛徽章:
0
2 [报告]
发表于 2009-04-13 17:36 |只看该作者
应该有的,但本质上也是线性访问。

lisp 里有 list-ref


  1. (list-ref '(1, 2, 3) 2)
复制代码


haskell 有 !!


  1. [Prelude> [1,2,3]!!2
  2. 3
  3. Prelude> [1,2,3]!!0
  4. 1
复制代码

论坛徽章:
0
3 [报告]
发表于 2009-04-13 17:49 |只看该作者
原帖由 win_hate 于 2009-4-13 17:36 发表
应该有的,但本质上也是线性访问。

lisp 里有 list-ref


(list-ref '(1, 2, 3) 2)


haskell 有 !!


[Prelude> [1,2,3]!!2
3
Prelude> [1,2,3]!!0
1



3ks,列表过大时线性访问似乎不是太理想

论坛徽章:
0
4 [报告]
发表于 2009-04-13 17:55 |只看该作者
可以看看 erlang 里有没有数组之类的结构。

scheme 中有 vector,Haskell 有 array。

论坛徽章:
0
5 [报告]
发表于 2009-04-13 18:40 |只看该作者
erlang有dict           Key-value dictionary.

论坛徽章:
0
6 [报告]
发表于 2009-04-13 18:48 |只看该作者
嗯,谢谢,可能是Tuple


1> P = {adam,24,{july,29}}.
{adam,24,{july,29}}
2> element(1,P).
adam
3> element(3,P).
{july,29}

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
7 [报告]
发表于 2009-04-13 19:05 |只看该作者
元组可不是干这个用的。
你这种情况下就应该用 dict。

论坛徽章:
0
8 [报告]
发表于 2009-04-17 08:06 |只看该作者
lists:nth(2,[1,2,3]).

论坛徽章:
0
9 [报告]
发表于 2009-04-24 13:34 |只看该作者
谢谢二位  
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP