链接:https://codeforces.com/problemset/problem/1512/C
题意:构造满足条件的字符串
题解:没啥解,就硬凑;具体看代码;
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
int t;
cin >> t;
while (t--)
{
int a, b, n;
cin >> a >> b;
n = a + b;
string s;
cin >> s;
for (int i = 0; i < n; i++)
{
if (s[i] == '?')s[i] = s[n - i - 1];
}
a -= count(s.begin(), s.end(), '0');//返回字符串中所有0的数量
b -= count(s.begin(), s.end(), '1');//返回字符串中所有1的数量
for (int i = 0; i <= n / 2; i++)
{
if (i != n - i - 1 && s[i] == '?')
{
if (a > 1)
{
s[i] = s[n - i - 1] = '0';
a -= 2;
}
else if (b > 1)
{
s[i] = s[n - i - 1] = '1';
b -= 2;
}
}
else if (s[i] == '?')//中间位置特判
{
if (a)
{
s[i] = '0';
a--;
}
else
{
s[i] = '1';
b--;
}
}
}
string t = s;
reverse(t.begin(), t.end());//反转字符串
if (t == s && a == 0 && b == 0)
cout << s << '\n';
else
cout << "-1\n";
}
return 0;
}