1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
|
//![includes]
#include <iostream>
#include <seqan/file.h>
#include <seqan/sequence.h>
using namespace seqan2;
//![includes]
//![main]
int main()
{
//![main]
//![sequences]
// Initialization
String<char> text = "This is an awesome tutorial to get to know SeqAn!";
String<char> pattern = "tutorial";
//![sequences]
//![score]
String<int> score;
//![score]
//![resize]
resize(score, length(text) - length(pattern) + 1);
//![resize]
//![similarity]
// Computation of the similarities
// Iteration over the text (outer loop)
for (unsigned i = 0; i < length(text) - length(pattern) + 1; ++i)
{
int localScore = 0;
// Iteration over the pattern for character comparison
for (unsigned j = 0; j < length(pattern); ++j)
{
if (text[i + j] == pattern[j])
++localScore;
}
score[i] = localScore;
}
//![similarity]
//![print]
// Printing the result
for (unsigned i = 0; i < length(score); ++i)
std::cout << score[i] << " ";
std::cout << std::endl;
//![print]
//![end]
return 0;
}
//![end]
|