在线二叉树&哈夫曼生成工具

在线二叉树生成

在这里插入图片描述
必须有中序,前序和后序填写一个即可,就可以生成二叉树的另外一个序列,并可以看到右侧生成的数

在线哈夫曼生成

在这里插入图片描述
可以快速生成对应的哈夫曼数 格式如示例即可,并可以快速计算出带权总值

绘出图像的主要代码

var draw = function (binTree, left, right, y) {
    canvas.height=canvas.height;
    ctx.font = "18px Georgia";
    // init();
    let drawTree = function (binTree, left, right, y) {
        ctx.beginPath();
        let x = (left + right) / 2;
        ctx.arc(x, y, r, 0, 2 * Math.PI);
        ctx.stroke();
        if (binTree == null) {
            return;
        }
        ctx.fillText(binTree.data, x - r + 5, y + 5);
        //画左
        if(binTree.left!=null){
            ctx.beginPath();
            ctx.moveTo(x, y + r);
            ctx.lineTo(left / 2 + x / 2, y + layerHeight - r);
            ctx.stroke();
            drawTree(binTree.left, left, x, y + layerHeight);
        }
        if(binTree.right!=null){
            ctx.beginPath();
            ctx.moveTo(x, y + r);
            ctx.lineTo(right / 2 + x / 2, y + layerHeight - r);
            ctx.stroke();
            drawTree(binTree.right, x, right, y + layerHeight);
        }
        
    }
    drawTree(binTree, left, right, y);
}

链接-nolink just tpye url in your address

easycode.top

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值