-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLongest_Common_Subsequence_three_seq.c
63 lines (59 loc) · 1.74 KB
/
Longest_Common_Subsequence_three_seq.c
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
53
54
55
56
57
58
59
60
61
62
63
#include<stdio.h>
#include<stdlib.h>
#include<limits.h>
void long_common_sub3(int*, int, int*, int, int*, int, int***);
int max(int*);
int max(int* arr)
{
int max_val = INT_MIN;
for(int i = 0; i < 6; i++) max_val = ((arr[i] > max_val) ? arr[i] : max_val);
return max_val;
}
void long_common_sub3(int* arr1, int n1, int* arr2, int n2, int* arr3, int n3, int*** matrix)
{
matrix = (int***)calloc(n1, sizeof(int**));
int i = 0, j = 0, k = 0;
for(i = 0; i < n1; i++)
{
matrix[i] = (int**)calloc(n2, sizeof(int*));
for(j = 0; j < n2; j++) matrix[i][j] = (int*)calloc(n3, sizeof(int));
}
for(i = 1; i < n1; i++)
{
for(j = 1; j < n2; j++)
{
for(k = 1; k < n3; k++)
{
int temp_arr[6];
temp_arr[0] = matrix[i - 1][j][k];
temp_arr[1] = matrix[i - 1][j][k];
temp_arr[2] = matrix[i][j - 1][k];
temp_arr[3] = matrix[i][j - 1][k];
temp_arr[4] = matrix[i][j][k - 1];
temp_arr[5] = matrix[i][j][k - 1];
if((arr1[i - 1] != arr2[j - 1])||(arr2[j - 1] != arr3[k - 1])||(arr3[k - 1] != arr1[i - 1])) matrix[i][j][k] = max(temp_arr);
else matrix[i][j][k] = matrix[i - 1][j - 1][k - 1] + 1;
}
}
}
printf("%d", matrix[i - 1][j - 1][k - 1]);
}
void main()
{
int n1, n2, n3, i = 0;
scanf("%d", &n1);
int* arr1 = (int*)calloc(n1, sizeof(int));
for(i = 0; i < n1; i++) scanf("%d", &arr1[i]);
scanf("%d", &n2);
int* arr2 = (int*)calloc(n2, sizeof(int));
for(i = 0; i < n2; i++) scanf("%d", &arr2[i]);
scanf("%d", &n3);
int* arr3 = (int*)calloc(n3, sizeof(int));
for(i = 0; i < n3; i++) scanf("%d", &arr3[i]);
int*** matrix;
long_common_sub3(arr1, n1 + 1, arr2, n2 + 1, arr3, n3 + 1, matrix);
free(arr1);
free(arr2);
free(arr3);
free(matrix);
}