找回密码
 注册
Simdroid-非首页
查看: 77|回复: 1

[基础概念] subsets的算法是怎么样的

[复制链接]
发表于 2013-6-14 17:06:27 | 显示全部楼层 |阅读模式 来自 德国
我想用fortran实现mathematica里subset[list, {k}]的功能。就是算出所有包含k个元素的子数列。有谁知道怎么处理吗? 先谢过了
发表于 2013-6-16 17:27:09 | 显示全部楼层 来自 北京
Simdroid开发平台
  1. subsets[ls_, 0] := {{}};
  2. subsets[{}, k_] := {};
  3. subsets[{x_, xs___}, k_] :=
  4.   Table[{x}~Join~i, {i, subsets[{xs}, k - 1]}]~Join~subsets[{xs}, k];

  5. subsets[Range[5], 3] == Subsets[Range[5], {3}]

  6. Sort@Fold[#~Join~Table[i~Join~{#2}, {i, #}] &, {{}}, Range[5]] ==
  7. Subsets[Range[5]]
复制代码
回复 不支持

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|小黑屋|联系我们|仿真互动网 ( 京ICP备15048925号-7 )

GMT+8, 2024-4-27 17:33 , Processed in 0.027600 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5 Licensed

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表