题意:给定的数字变成一个奇数,但是各个位数之和为偶数。
思路:1.因为是随意变嘛,就直接截取一个奇数就可以了。
2.可以从最后往前删,直到是奇数为止,再判断位数之和,是奇数的话删除一个奇数,(前导不为零!),偶数的话就直接输出。
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
char s[3010];
int main()
{
int t;
scanf("%d", &t);
while (t--) {
int n;
scanf("%d%s", &n, s + 1);
int a = -1, b = -1;
for (int i = 1; i <= n; i++)
if ((s[i] - '0') & 1) {
if (a == -1)
a = i;
else {
b = i;
break;
}
}
if (a != -1 && b != -1) {
for (int i = a; i <= b; i++)
printf("%c", s[i]);
printf("\n");
} else
printf("-1\n");
}
}