本文整理汇总了C++中DNA::slice方法的典型用法代码示例。如果您正苦于以下问题:C++ DNA::slice方法的具体用法?C++ DNA::slice怎么用?C++ DNA::slice使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DNA
的用法示例。
在下文中一共展示了DNA::slice方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: FrequentWords
vector<DNA<false>> FrequentWords(const DNA<IsCyclic>& dnaString, int k) {
//Initialize dictionary
unordered_map<DNA<false>, int> counts{ };
size_t n{ dnaString.size() };
//Fill dictionary and count kmer frequencies
int maxCount{ 1 };
for (size_t i = 0; i < n - k + 1; i++) {
DNA<false> part{ dnaString.slice(i, k) };
auto it = counts.find(part);
if (it == end(counts)) {
counts[part] = 1;
} else {
it->second++;
if (maxCount < it->second) maxCount = it->second;
};
};
//Extract most frequent words
vector<DNA<false>> most_frequent_words{ };
for (auto& p : counts) if (p.second == maxCount) most_frequent_words.push_back(p.first);
return most_frequent_words;
};