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); //继续递归, 当然可以用迭代代替
}
相关推荐
ZhengEnCi34 分钟前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 小时前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan2 小时前
AI小镇 - 涌现
算法·架构
AI工程架构师5 小时前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_5 小时前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮19 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
CoovallyAIHub2 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing2 天前
Hot100-Day14-T33搜索旋转排序数组
算法