Cod sursa(job #1993565)

Utilizator Mircea_DonciuDonciu Mircea Mircea_Donciu Data 23 iunie 2017 11:55:17
Problema Invers Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.66 kb
#include <cstdio>
#include <cstring>
#include <cassert>
using namespace std;
int nrt, n;
char v[10005];
bool solve(int st, int dr, bool type)
{
    int ans = 2;
    if(st == dr)
        return (v[st] % 2 == 0);
    if(type==1&&v[dr]==v[st]&&v[dr]==9) return 0;
    if(type==0&&v[dr]==9&&v[st]==0) return 0;
    if(dr-st==1)
    {
        if(type)
            return v[st]==v[dr]+1;
        else
            return v[st]==v[dr];
    }
    if(v[dr]!=v[st]&&(v[dr]+1)%10!=v[st]) return 0;
    if(type==1&&(v[st]==v[dr]||v[dr]<9))
    {
        v[dr-1]--;
        int j;
        for(j=dr-1; j>st && v[j]==-1; j--)
        {
            v[j]=9;
            v[j - 1]--;
        }
    }

    if(ans == 2){
        if(v[st] == v[dr])
            ans = solve(st + 1, dr - 1, 0);
        else
            ans = solve(st + 1, dr - 1, 1);
    }

    if(type == 1 && (v[st] == v[dr] || v[dr] < 9)){
        v[dr - 1]++;
        for(int j = dr - 1; j > st && v[j] == 10; j--){
            v[j] = 0;
            v[j - 1]++;
        }
    }

    return ans;
}
int main()
{
    freopen("invers.in", "r", stdin);
    freopen("invers.out", "w", stdout);
    int i;
    scanf("%d\n", &nrt);
    while(nrt)
    {
        nrt--;
        fgets(v + 1, 10005, stdin);
        n = strlen(v + 1) - 1;
        assert(v[n + 1] == '\n');
        for(i = 1; i <= n; i++)
            v[i] -= '0';
        if((v[1] != 1 || v[n] != 0) && solve(1, n, 0)){
            printf("DA\n");
            continue;
        }
        if(v[1] == 1 && solve(2, n, 1)){
            printf("DA\n");
            continue;
        }
        printf("NU\n");
    }
    return 0;
}