Created
March 21, 2012 01:42
-
-
Save truncs/2143525 to your computer and use it in GitHub Desktop.
parallel2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#include <iostream> | |
#include <algorithm> | |
#include <string> | |
#include <cstdlib> | |
using namespace std; | |
int main(){ | |
int n; | |
string string_n; | |
string s1; | |
string s2; | |
string s3; | |
string s4; | |
getline(cin, string_n); | |
n = atoi(string_n.c_str()); | |
int N = n + 1; | |
int D[N][N], I[N][N], G[N][N]; | |
const int g_e = 1; | |
const int g_i = 2; | |
cout<<getline(cin,s1); | |
cout<<getline(cin,s2); | |
cout<<n<<endl; | |
cout<<s1<<endl; | |
cout<<s2<<"here"<<endl; | |
for (int x = 0; x < 16; x++) { | |
cout<<s1[x]; | |
} | |
cout<<endl; | |
for (int x = 0; x < 16; x++) { | |
cout<<s2[x]; | |
} | |
cout<<endl; | |
// Forward Pass | |
for (int slice = 0; slice < 2*n - 1; slice++) | |
{ | |
int z = slice < slice ? 0 : slice -n + 1; | |
cilk_for (int i=z ; k<= slice - z; i++) | |
{ | |
int j = slice - i; | |
if (i == 0 && j == 0) | |
G[i][j] = 0; | |
if (i == 0 && j > 0) { | |
G[i][j] = g_i + g_e *j; | |
D[0][j] = G[0][j] + g_e; | |
} | |
if ( i > 0 && j == 0) { | |
G[i][j] = g_i + g_e *i; | |
I[i][0] = G[i][0] + g_e; | |
} | |
if (i > 0 && j > 0) { | |
D[i][j] = min(D[i - 1][j] , G[i - 1][j] + g_i) + g_e; | |
I[i][j] = min(I[i][j -1] , G[i][j - 1] + g_i) + g_e; | |
int s_cost = s1[i - 1] == s2[j -1] ? 0 : 1; | |
int temp = min(D[i][j], I[i][j]); | |
G[i][j] = min(G[i -1][j -1] + s_cost, temp); | |
} | |
} | |
} | |
// Backward pass | |
int i = N -1; | |
int j = N - 1; | |
// If the previous element is the diagnol element | |
// then print both the characters in the string, | |
// else if the previous element is the one in the | |
// insert element then insert insert a gap | |
// in the first string else it's the delete one | |
// then insert a gap in the second string | |
for (int i = 0; i < N; ++i){ | |
for (int j=0; j< N; ++j) { | |
cout<<G[i][j]<<"\t"; | |
} | |
cout<<endl; | |
} | |
cout<<"I Matrix"<<endl; | |
for (int i = 0; i < N; ++i){ | |
for (int j=0; j< N; ++j) { | |
cout<<I[i][j]<<"\t"; | |
} | |
cout<<endl; | |
} | |
cout<<"D Matrix"<<endl; | |
for (int i = 0; i < N; ++i){ | |
for (int j=0; j< N; ++j) { | |
cout<<D[i][j]<<"\t"; | |
} | |
cout<<endl; | |
} | |
while(i != 0 && j != 0) { | |
if (i == 0 && j > 0){ | |
j = j -1; | |
cout<<"-"<<" "<<s2[j]; | |
cout<<" "<<i<<"\t"<<j<<endl; | |
s3 = '-' + s3; | |
s4 = s2[j] + s4; | |
} | |
else if ( i > 0 && j == 0) { | |
i = i -1; | |
cout<<s1[i]<<" "<<"-"; | |
cout<<" "<<i<<"\t"<<j<<endl; | |
s3 = s1[i] + s3; | |
s4 = '-' + s4; | |
} | |
else if (i > 0 && j > 0) { | |
int values[3] = {G[i -1][j - 1], G[i -1][j], G[i][j -1]}; | |
int index = 0; | |
if (values[1] <= values[index]) | |
index = 1; | |
if(values[2] < values[index]) | |
index = 2; | |
switch(index) { | |
case 0: | |
i = i - 1; | |
j = j -1; | |
cout<<s1[i]<<" "<<s2[j]; | |
cout<<" "<<i<<"\t"<<j<<endl; | |
s3 = s1[i] + s3; | |
s4 = s2[j] + s4; | |
break; | |
case 1: | |
i = i -1; | |
cout<<s1[i]<<" "<<"-"; | |
cout<<" "<<i<<"\t"<<j<<endl; | |
s3 = s1[i] + s3; | |
s4 = '-' + s4; | |
break; | |
case 2: | |
j = j -1; | |
cout<<"-"<<" "<<s2[j]; | |
cout<<" "<<i<<"\t"<<j<<endl; | |
s3 = '-' + s3; | |
s4 = s2[j] + s4; | |
break; | |
} | |
} | |
} | |
cout<<G[N-1][N -1]<<endl; | |
cout<<s3<<endl; | |
cout<<s4<<endl; | |
return 0; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment