-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBuild a Palindrome
119 lines (107 loc) · 2.48 KB
/
Build a Palindrome
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include <bits/stdc++.h>
using namespace std;
string maxi(string s1, string s2){
int flag=0;
if(s1==s2)
return s1;
if(s1.length()>s2.length())
return s1;
else if(s2.length()>s1.length())
return s2;
else{
for(int i=0;i<s1.length();i++){
if(s1[i]<s2[i]){
flag=1;
break;
}
if(s2[i]<s1[i]){
break;
}
}
if(flag==1)
return s1;
else
return s2;
}
}
string palin(string s){
int i=0, j=s.length()-1;
string ans;
while(i<=j){
if(s[i]==s[j]){
int shuru=i, khatam=j;
int flag=0;
string ans1, ans2;
while(shuru<khatam){
if(s[shuru]!=s[khatam]){
flag=1;
break;
}
ans1=ans1+s[shuru];
ans2=s[khatam]+ans2;
shuru++;
khatam--;
}
if(shuru==khatam)
ans1+=s[shuru];
if(flag==0){
ans=ans1+ans2;
break;
}
}
j--;
}
return ans;
}
string buildPalindrome(string a, string b) {
string s;
reverse(b.begin(), b.end());
int m=a.length(), n=b.length();
vector<vector<string> > dp;
dp.reserve(10000);
for(int i=0;i<=m;i++){
vector<string> tempo;
tempo.reserve(10000);
for(int j=0;j<=n;j++){
tempo.push_back("");
}
dp.push_back(tempo);
}
for(int i=1;i<=m;i++){
for(int j=1;j<=n;j++){
if(a[i-1]==b[j-1])
dp[i][j]=dp[i-1][j-1]+a[i-1];
else
dp[i][j]="";
}
}
for(int i=0;i<=m;i++){
for(int j=0;j<=n;j++){
if(dp[i][j].length()!=0){
string temp=dp[i][j];
reverse(temp.begin(), temp.end());
s = maxi(s, dp[i][j] + maxi(palin(a.substr(i)), palin(b.substr(j))) + temp);
}
}
}
if(s=="")
return "-1";
return s;
}
int main()
{
ofstream fout(getenv("OUTPUT_PATH"));
int t;
cin >> t;
cin.ignore(numeric_limits<streamsize>::max(), '\n');
for (int t_itr = 0; t_itr < t; t_itr++) {
string a;
getline(cin, a);
string b;
getline(cin, b);
string result = buildPalindrome(a, b);
fout << result << "\n";
}
fout.close();
return 0;
}