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); //继续递归, 当然可以用迭代代替
}
相关推荐
孤廖3 分钟前
吃透 C++ 栈和队列:stack/queue/priority_queue 用法 + 模拟 + STL 标准实现对比
java·开发语言·数据结构·c++·人工智能·深度学习·算法
BanyeBirth32 分钟前
C++动态规划——LIS(最长不下降子序列)
算法·动态规划
小龙报33 分钟前
《算法通关指南---C++编程篇(3)》
开发语言·c++·算法·visualstudio·学习方法·visual studio
凤山老林38 分钟前
排序算法:详解插入排序
java·开发语言·后端·算法·排序算法
知星小度S1 小时前
算法训练之多源BFS
算法·宽度优先
2201_758875441 小时前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
代码不停2 小时前
Java前缀和算法题目练习
java·开发语言·算法
courniche2 小时前
分组密码常见结构简介
算法·密码学
涤生z2 小时前
list.
开发语言·数据结构·c++·学习·算法·list
茜茜西西CeCe3 小时前
数字图像处理-图像增强(2)
人工智能·算法·计算机视觉·matlab·数字图像处理·图像增强·陷波滤波器