本文整理汇总了C++中Probe::conflict方法的典型用法代码示例。如果您正苦于以下问题:C++ Probe::conflict方法的具体用法?C++ Probe::conflict怎么用?C++ Probe::conflict使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Probe
的用法示例。
在下文中一共展示了Probe::conflict方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: GenProbeSequenceTemplate
void GenProbeSequenceTemplate (ProbeSequence &seq, unsigned M, unsigned T)
{
ProbeSequence scores;
GenExpectScores(scores, M);
assert(T > 0);
std::priority_queue<Probe, std::vector<Probe>, ProbeGT> heap;
Probe init;
init.mask = init.shift = 0;
init.score = 0;
init.reserve = 0;
heap.push(init);
seq.clear();
for (;;)
{
if (heap.empty()) break;
seq.push_back(heap.top());
if (seq.size() == T) break;
Probe shift = heap.top();
heap.pop();
for (unsigned next = shift.reserve; next < 2 * M; ++next)
{
if (!shift.conflict(scores[next]))
{
Probe tmp = shift + scores[next];
tmp.reserve = next + 1;
heap.push(tmp);
}
}
}
}