首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Promela中的递归数据类型

Promela中的递归数据类型
EN

Stack Overflow用户
提问于 2013-12-31 23:30:46
回答 1查看 268关注 0票数 3

我正在尝试用Promela创建一个B-Tree,这样我就可以证明一些关于它的东西,然而,Promela似乎不支持递归数据类型。这不起作用:

代码语言:javascript
复制
#define n 2
typedef BTreeNode
{
    int keys[2*n-1];
    BTreeNode children[2*n];
    int c;
};

我如何在Promela中创建B-Tree,如果我不能,你会推荐哪个工具?我考虑过QuickCheck和Prolog。然而,用Prolog制作B-Tree也很难。

EN

回答 1

Stack Overflow用户

发布于 2014-01-05 02:54:37

您将使用一个静态定义的节点数组中的索引来表示子节点。如下所示:

代码语言:javascript
复制
#define n 2

#define BTreeNodeId   byte
typedef BTreeNode {
  BTreeNodeId my_id;
  int keys[2*n-1];
  BTreeNodeId children[2*n];
  int c;
};

BTreeNode nodes [10];
byte next_node_id = 0;

这样,您就可以通过递增next_node_id来“分配”节点,并且可以通过使用子节点的id引用nodes来访问子节点。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20859517

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档