本文整理汇总了C++中DNA::size方法的典型用法代码示例。如果您正苦于以下问题:C++ DNA::size方法的具体用法?C++ DNA::size怎么用?C++ DNA::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DNA
的用法示例。
在下文中一共展示了DNA::size方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: translateToDnaPhenotypicOrdinal
tsp_individual_multi::DNA tsp_individual_multi::translateToDnaPhenotypicOrdinal(const DNA trait){
DNA ordinal;
DNA tmp;
for(int i=0;i<trait.size();i++){
tmp.push_back(i);
}
ordinal.resize(trait.size());
for(int i=0;i<trait.size();i++){
ordinal[i] = tmp[trait[i]];
tmp.erase(tmp.begin() + trait[i]);
}
return ordinal;
}
示例2: translateToDnaPhenotypicTrait
tsp_individual_multi::DNA tsp_individual_multi::translateToDnaPhenotypicTrait(const DNA ordinal){
DNA trait;
DNA tmp;
for(int i=0;i<ordinal.size();i++){
tmp.push_back(i);
}
for(int i=0;i<ordinal.size();i++){
for(int j=0;j<tmp.size();j++){
if(ordinal[i] == tmp[j]){
trait.push_back(j);
tmp.erase(tmp.begin() + j);
break;
}
}
}
return trait;
}
示例3: 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;
};