本文整理汇总了C++中Traits::merge_modifier方法的典型用法代码示例。如果您正苦于以下问题:C++ Traits::merge_modifier方法的具体用法?C++ Traits::merge_modifier怎么用?C++ Traits::merge_modifier使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Traits
的用法示例。
在下文中一共展示了Traits::merge_modifier方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: propagate
void propagate(node_type *p) const {
if(p == nullptr){ return; }
const size_t k = size(p->children[0]);
const auto mod_l_cr = m_traits.split_modifier(p->modifier, k);
const auto mod_c_r = m_traits.split_modifier(mod_l_cr.second, 1);
if(p->children[0] != nullptr){
p->children[0]->modifier = m_traits.merge_modifier(
p->children[0]->modifier, mod_l_cr.first);
refresh(p->children[0]);
}
if(p->children[1] != nullptr){
p->children[1]->modifier = m_traits.merge_modifier(
p->children[1]->modifier, mod_c_r.second);
refresh(p->children[1]);
}
p->value = m_traits.resolve(1, p->value, mod_c_r.first);
p->modifier= m_traits.default_modifier();
}
示例2: modify
/**
* @brief 区間更新
*
* インデックスが区間 [l, r) に含まれる要素すべてxに従って更新する。
* - 時間計算量: \f$ O(\log{n}) \f$
*
* @param[in] l 区間の始端
* @param[in] r 区間の終端
* @param[in] x 更新クエリ
*/
void modify(size_t l, size_t r, const modifier_type &x){
const auto p0 = split(m_root, l);
const auto p1 = split(p0.second, r - l);
node_type *c = p1.first;
if(c != nullptr){
c->modifier = m_traits.merge_modifier(c->modifier, x);
refresh(c);
}
m_root = merge(merge(p0.first, c), p1.second);
}