SPOJ: PALIN - следующий палиндром: WA для теста 1 - PullRequest
0 голосов
/ 30 июня 2019

Код проходит тестовый пример 0, но выдает WA для Тестового случая 1. Пожалуйста, помогите мне, поскольку я пытаюсь решить эту проблему уже несколько дней.

Я сделал это, используя строки, так как нет, может иметь 10e6 цифр.

Я перепробовал все тестовые примеры из набора инструментов spoj или из любого другого источника. Все они дают правильный вывод.

Вот ссылка на мой код: https://ideone.com/YqzFRn

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.math.BigInteger;

class Main {
    public static void main(String[] args) throws NumberFormatException, IOException {
         BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int t = Integer.parseInt(br.readLine());
        while (t-- > 0) {
            String s = br.readLine();
            s = s.trim();
            if(s.charAt(0) == '0') {
                while(s.charAt(0) == '0')
                    s = s.substring(1);
            }
            if (all9(s)) {
                BigInteger b = new BigInteger(s);
                b = b.add(new BigInteger("2"));
                System.out.print(b);
                continue;

            }
            int i = 0, j = s.length() - 1;

            int mid = (i + j) / 2;

            String f = s.substring(0, mid + 1);
            String rev = rev((s.length() % 2 == 0) ? s.substring(0, mid + 1) : s.substring(0, mid));

            String ans = f + rev;

            while (ans.compareTo(s) <= 0) {
                ans = big(ans);
            }

            System.out.println(ans);

        }

    }

    private static boolean all9(String s) {
        // TODO Auto-generated method stub
        int i = 0;
        while (i < s.length()) {
            if (s.charAt(i) != '9')
                return false;
            i++;
        }
        return true;
    }

    private static String big(String ans) {
        int mid = ans.length() / 2;
        String s = "";
        String f = "";
        if (ans.length() % 2 == 0) {
            f = ans.substring(0, mid);
        } else {
            f = ans.substring(0, mid + 1);
        }
        BigInteger b = new BigInteger(f);
        b = b.add(new BigInteger("1"));
        s = s + b;
        String rev = rev((ans.length() % 2 == 0) ? s : s.substring(0, mid));
        ans = s + rev;

        return ans;
    }

    private static String rev(String s) {
        // TODO Auto-generated method stub
        return new StringBuilder(s).reverse().toString();
    }

}
...