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); //继续递归, 当然可以用迭代代替
}
相关推荐
wabs66620 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641320 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚21 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本21 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov1 天前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫1 天前
特征工程处理
人工智能·算法·机器学习
z落落1 天前
C#参数区别
java·算法·c#
c238561 天前
vector(下)
数据结构·算法
z落落1 天前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法
wyy185100737281 天前
双路并行:一套匹配算法如何解决中文制单的两大核心难题
算法·ai·crm·crm系统