Ejemplo n.º 1
0
        private void FindLongestPalindromes(PalindromeWord firstWord, PalindromeWord secondWord)
        {
            var firstLastIndex  = 0;
            var secondLastIndex = 0;

            FindPalindromeParts(firstWord, secondWord, out firstLastIndex, out secondLastIndex);
            firstWord.ExcludePalindromeAndFindInners();
            secondWord.ExcludePalindromeAndFindInners();

            foreach (var innerPalindrome in firstWord.InnerPalindromes)
            {
                if (firstLastIndex != 0 && innerPalindrome.StartIndex == firstLastIndex)
                {
                    m_Palindromes.Add($"{firstWord.PalindromePart}{innerPalindrome.Palindrome}{secondWord.PalindromePart}");
                }

                /**
                 * TODO: add inner palindromes which are longer than palindromes in the palindromes list
                 */
            }

            foreach (var innerPalindrome in secondWord.InnerPalindromes)
            {
                if (secondLastIndex >= innerPalindrome.Length && innerPalindrome.StartIndex + innerPalindrome.Length == secondLastIndex)
                {
                    m_Palindromes.Add($"{firstWord.PalindromePart}{innerPalindrome.Palindrome}{secondWord.PalindromePart}");
                }
            }

            ConcatPalindromeParts(firstWord, secondWord);
        }
Ejemplo n.º 2
0
        //################################################################################
        #region Private Members

        private void SolveProblem()
        {
            var querySize = Convert.ToInt32(Console.ReadLine());

            for (int q = 0; q < querySize; q++)
            {
                var firstInput  = Console.ReadLine();
                var secondInput = Console.ReadLine();

                PalindromeWord firstWord  = new PalindromeWord(firstInput);
                PalindromeWord secondWord = new PalindromeWord(secondInput);

                FindLongestPalindromes(firstWord, secondWord);

                if (m_Palindromes.Count == 0)
                {
                    Console.WriteLine("-1");
                }
                else
                {
                    Console.WriteLine(GetTheLongestPalindrome());
                }

                m_Palindromes.Clear();
            }
        }
Ejemplo n.º 3
0
        private void ConcatPalindromeParts(PalindromeWord firstWord, PalindromeWord secondWord)
        {
            var firstPart  = firstWord.PalindromePart;
            var secondPart = secondWord.PalindromePart;

            var firstPartIndex  = firstWord.Input.IndexOf(firstPart, StringComparison.Ordinal);
            var secondPartIndex = secondWord.Input.IndexOf(secondPart, StringComparison.Ordinal);

            //firstpart sonda ve secondpart başta ise => firstpart + secondpart
            if ((firstPartIndex + firstPart.Length >= firstWord.Input.Length) && secondPartIndex == 0)
            {
                var palindromeCandidate = $"{firstPart}{secondPart}";
                if (PalindromeWord.IsPalindrome(palindromeCandidate))
                {
                    m_Palindromes.Add(palindromeCandidate);
                }
            }

            //firstpart sonda ve secondpart ortada ise => firstpart + secondpart[i] + secondpart
            if ((firstPartIndex + firstPart.Length >= firstWord.Input.Length) && secondPartIndex > 0)
            {
                var palindromeCandidate = $"{firstPart}{secondWord.Input[secondPartIndex - 1]}{secondPart}";
                if (PalindromeWord.IsPalindrome(palindromeCandidate))
                {
                    m_Palindromes.Add(palindromeCandidate);
                }
            }

            //firstpart ortada ve secondpart başta ise => firstpart + firstpart[i] + secondpart
            if ((firstPartIndex + firstPart.Length < firstWord.Input.Length) && secondPartIndex == 0)
            {
                var palindromeCandidate = $"{firstPart}{firstWord.Input[firstPartIndex + firstPart.Length]}{secondPart}";
                if (PalindromeWord.IsPalindrome(palindromeCandidate))
                {
                    m_Palindromes.Add(palindromeCandidate);
                }
            }

            //firstpart ortada ve secondpart ortada ise => firstpart + firstpart[i] + secondpart yada firstpart +secondpart[i] + secondpart
            if ((firstPartIndex + firstPart.Length < firstWord.Input.Length) && secondPartIndex > 0)
            {
                var palindromeCandidate = $"{firstPart}{firstWord.Input[firstPartIndex + firstPart.Length]}{secondPart}";
                if (PalindromeWord.IsPalindrome(palindromeCandidate))
                {
                    m_Palindromes.Add(palindromeCandidate);
                }

                palindromeCandidate = $"{firstPart}{secondWord.Input[secondPartIndex - 1]}{secondPart}";
                if (PalindromeWord.IsPalindrome(palindromeCandidate))
                {
                    m_Palindromes.Add(palindromeCandidate);
                }
            }
        }
Ejemplo n.º 4
0
        private void FindPalindromeParts(PalindromeWord firstWord, PalindromeWord secondWord, out int firstPalindromeLastIndex, out int secondPalindromeLastIndex)
        {
            var temp           = string.Empty;
            var first          = firstWord.Input;
            var second         = secondWord.Reverse;
            var palindromePart = string.Empty;

            var index  = 0;
            var length = 1;

            firstPalindromeLastIndex  = 0;
            secondPalindromeLastIndex = 0;
            while (true)
            {
                if ((index + length) >= first.Length)
                {
                    break;
                }

                temp = first.Substring(index, length);
                if (second.Contains(temp))
                {
                    if ((temp.Length > palindromePart.Length) ||
                        ((temp.Length == palindromePart.Length) && (string.Compare(temp, palindromePart) < 0)) ||
                        string.IsNullOrEmpty(palindromePart))
                    {
                        palindromePart           = temp;
                        firstPalindromeLastIndex = index + palindromePart.Length;
                        temp = string.Empty;
                    }
                    length++;
                    continue;
                }
                index++;
                length = 1;
            }

            firstWord.PalindromePart  = palindromePart;
            secondWord.PalindromePart = PalindromeWord.ReverseWord(palindromePart);
            secondPalindromeLastIndex = secondWord.Input.IndexOf(secondWord.PalindromePart);
        }