美文网首页
枚举二叉树

枚举二叉树

作者: 赵枝阳 | 来源:发表于2019-05-08 15:33 被阅读0次

有1-n个节点, 每两个节点可以合并产生一个新的节点, 枚举一下这样的二叉树。

思路: 采用递归的方式, 每次选择已有的节点里面选择两个点进行合并,

最多有2*n-1个节点(满二叉树的性质),define maxn = 2 * n;

cur = n

for (int i = 0; i < n; i++) {

    ok[i++] = 1;

}

build_tree(1)

void build_tree(dep) {

    if (dep == n) return;

    for (int i = 0; i < maxn; i++) {

        if (ok[i]) {

            for (int j = 0; j < maxn; j++) {

                if (ok[j] && i != j) {

                    ok[i] = ok[j] = 0;

                    int id = cur++;

                    w[id ] = w[i] + w[j];

                    ok[id] = 1;

                    build_tree(dep + 1);

                    ok[cur--] = 0;

                    ok[i] = ok[j] = 1;

            }

        }

    }

}

}

相关文章

  • 枚举二叉树

    有1-n个节点, 每两个节点可以合并产生一个新的节点, 枚举一下这样的二叉树。 思路: 采用递归的方式, 每次选择...

  • C#枚举及与枚举常数的转换

    1、枚举的定义 2、枚举绑定到comboBox 3、枚举常数转换为枚举string转枚举 数字值转枚举

  • Swift 基础笔记 - 枚举

    枚举 OC定义和使用枚举 Swift定义枚举类型 Swift判断枚举类型 枚举成员类型

  • 枚举类

    1.枚举类型的定义: 枚举类型定义的一般形式为 enum 枚举名{//枚举值表枚举值1;枚举值2;...} 在枚举...

  • 10、枚举与闭包

    枚举 枚举和普通类相比有什么优势 枚举类型、枚举名称与枚举值 枚举的比较运算 两个枚举之间可以使用等值比较(==)...

  • Swift与OC的语法简单对比(常用语法二)

    20- 枚举,枚举原始值,枚举相关值,switch提取枚举关联值 Swift枚举: Swift中的枚举比OC中的枚...

  • Swift 2 学习笔记 10.枚举

    课程来自慕课网liuyubobobo老师 枚举 枚举基础 枚举之原始值 枚举之关联值 枚举递归

  • swift3语法(八)

    枚举/结构体 枚举 定义形式enum 枚举名 { 枚举值} // 例如enum CompassPoint {...

  • C语言基础 之 枚举类型

    枚举类型 枚举类型: 列出所有可能的值 枚举类型的定义 枚举类型定义的一般格式:enum 枚举类型名 {枚举值表}...

  • 枚举

    枚举 Why:为什么需要枚举 What:枚举是什么; How:枚举怎么实现 When:枚举什么时候使用 Where...

网友评论

      本文标题:枚举二叉树

      本文链接:https://www.haomeiwen.com/subject/jtzmoqtx.html