merkle tree中文

Merkle tree

cpp 复制代码
#include <cstdlib>
#include <string>
#include <bitcoin/bitcoin.hpp>

BC_USE_LIBBITCOIN_MAIN

using namespace bc;

bc::hash_digest calculate_merkle_root(bc::hash_list &merkle);

int bc::main(int argc, char *argv[])
{
    bc::cout << "测试 merkle_tree" << std::endl;

    bc::hash_list tx_hashes{
        bc::hash_literal("0000000000000000000000000000000000000000000000000000000000000000"),
        bc::hash_literal("0000000000000000000000000000000000000000000000000000000000000011"),
        bc::hash_literal("0000000000000000000000000000000000000000000000000000000000000022"),
    };

    bc::hash_digest merkle_root = calculate_merkle_root(tx_hashes);

    bc::string right_hash = "d47780c084bad3830bcdaf6eace035e4c6cbf646d103795d22104fb105014ba3";
    assert(right_hash == bc::encode_hash(merkle_root));

    bc::cout << bc::encode_hash(merkle_root) << std::endl;

    return 0;
}

/**
 * 计算 merkle root
 */
bc::hash_digest calculate_merkle_root(bc::hash_list &merkle)
{
    if (merkle.empty())
    {
        return bc::null_hash;
    }

    if (merkle.size() == 1)
    {
        return merkle[0];
    }

    // 如果不是偶数, 则将最后一个元素复制一份凑成偶数
    if (0 != (merkle.size() & 1))
    {
        merkle.push_back(merkle.back());
    }
    assert(0 == (merkle.size() & 1));

    bc::hash_list tmp_merkle;
    for (auto it = merkle.begin(); it != merkle.end(); it += 2)
    {
        bc::data_chunk concat_data(bc::hash_size * 2);
        auto concat = bc::make_unsafe_serializer(concat_data.begin());
        concat.write_hash(*it);
        concat.write_hash(*(it + 1));
        //assert(concat.  == concat_data.end());

        bc::hash_digest new_root = bc::bitcoin_hash(concat_data);

        tmp_merkle.push_back(new_root);
    }

    merkle = tmp_merkle;          //size 变为原来的一半
    return calculate_merkle_root(merkle); //继续递归, 当然可以用迭代代替
}
相关推荐
JieE21212 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2020 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架