Najmniejszy palindrom po wymianie

Biorąc pod uwagę ciąg znaków zawierający kilka małych liter alfabetu i jedną kropkę (.) jako znak specjalny. Musimy zastąpić wszystkie kropki jakimś znakiem alfabetu w taki sposób, aby powstały ciąg znaków stał się palindromem. W przypadku wielu możliwych zamian musimy wybrać ciąg palindromowy, który jest najmniejszy leksykograficznie. Jeśli po wszystkich możliwych zamianach nie jest możliwa konwersja łańcucha na palindrom, wówczas wypisywany jest komunikat Niemożliwe. 

Przykłady:  

Input : str = ab..e.c.a Output : abcaeacba The smallest palindrome which can be made after replacement is 'abcaeacba' We replaced first dot with 'c' second dot with 'a' third dot with 'a' and fourth dot with 'b' Input : str = ab..e.c.b Output : Not Possible It is not possible to convert above string into palindrome 

Możemy rozwiązać ten problem w następujący sposób. Ponieważ wynikowy ciąg znaków musi być palindromem, możemy sprawdzić parę znaków innych niż kropka w samym uruchomieniu, jeśli nie pasują, wówczas bezpośredni powrót nie jest możliwy, ponieważ nowy znak możemy umieścić tylko w miejscu kropek, a nie gdziekolwiek indziej. 

Następnie iterujemy po znakach łańcucha, jeśli bieżącym znakiem jest kropka, następnie sprawdzamy jego sparowany znak (znak na (n – i -1) pozycji), jeśli ten znak jest również kropką, to możemy zastąpić oba znaki przez „a”, ponieważ „a” jest najmniejszą małą literą, co gwarantuje najmniejszy ciąg leksykograficzny na końcu. Zastąpienie obu dowolnym innym znakiem spowoduje leksykograficznie większy ciąg palindromiczny. W innym przypadku, jeśli sparowany znak nie jest kropką, to aby utworzyć palindrom łańcuchowy, musimy zastąpić bieżący znak jego sparowanym znakiem. 

So in short If both 'i' and 'n- i- 1' are dot replace them by ‘a’ If one of them is a dot character replace that by other non-dot character 

Powyższa procedura daje nam najmniejszy leksykograficzny ciąg palindromowy. 

Realizacja:

C++
   // C++ program to get lexicographically smallest   // palindrome string   #include          using     namespace     std  ;   // Utility method to check str is possible palindrome   // after ignoring .   bool     isPossiblePalindrome  (  string     str  )   {      int     n     =     str  .  length  ();      for     (  int     i  =  0  ;     i   <  n  /  2  ;     i  ++  )      {      /* If both left and right character are not    dot and they are not equal also then it    is not possible to make this string a    palindrome */      if     (  str  [  i  ]     !=     '.'     &&      str  [  n  -  i  -1  ]     !=     '.'     &&      str  [  i  ]     !=     str  [  n  -  i  -1  ])      return     false  ;      }      return     true  ;   }   // Returns lexicographically smallest palindrom   // string if possible   string     smallestPalindrome  (  string     str  )   {      if     (  !  isPossiblePalindrome  (  str  ))      return     'Not Possible'  ;      int     n     =     str  .  length  ();      // loop through character of string      for     (  int     i     =     0  ;     i      <     n  ;     i  ++  )      {      if     (  str  [  i  ]     ==     '.'  )      {      // if one of character is dot replace dot      // with other character      if     (  str  [  n     -     i     -     1  ]     !=     '.'  )      str  [  i  ]     =     str  [  n     -     i     -     1  ];      // if both character are dot then replace      // them with smallest character 'a'      else      str  [  i  ]     =     str  [  n     -     i     -     1  ]     =     'a'  ;      }      }      // return the result      return     str  ;   }   // Driver code to test above methods   int     main  ()   {      string     str     =     'ab..e.c.a'  ;      cout      < <     smallestPalindrome  (  str  )      < <     endl  ;      return     0  ;   }   
Java
   // Java program to get lexicographically    // smallest palindrome string   class   GFG      {   // Utility method to check str is   // possible palindrome after ignoring   static     boolean     isPossiblePalindrome  (  char     str  []  )   {   int     n     =     str  .  length  ;   for     (  int     i     =     0  ;     i      <     n     /     2  ;     i  ++  )   {      /* If both left and right character     are not dot and they are not     equal also then it is not     possible to make this string a    palindrome */      if     (  str  [  i  ]     !=     '.'     &&      str  [  n     -     i     -     1  ]     !=     '.'     &&      str  [  i  ]     !=     str  [  n     -     i     -     1  ]  )      return     false  ;   }   return     true  ;   }   // Returns lexicographically smallest    // palindrome string if possible   static     void     smallestPalindrome  (  char     str  []  )   {   if     (  !  isPossiblePalindrome  (  str  ))      System  .  out  .  println  (  'Not Possible'  );   int     n     =     str  .  length  ;   // loop through character of string   for     (  int     i     =     0  ;     i      <     n  ;     i  ++  )   {      if     (  str  [  i  ]     ==     '.'  )      {      // if one of character is dot       // replace dot with other character      if     (  str  [  n     -     i     -     1  ]     !=     '.'  )      str  [  i  ]     =     str  [  n     -     i     -     1  ]  ;      // if both character are dot       // then replace them with       // smallest character 'a'      else      str  [  i  ]     =     str  [  n     -     i     -     1  ]     =     'a'  ;      }   }   // return the result   for  (  int     i     =     0  ;     i      <     n  ;     i  ++  )      System  .  out  .  print  (  str  [  i  ]     +     ''  );   }   // Driver code   public     static     void     main  (  String  []     args  )   {      String     str     =     'ab..e.c.a'  ;      char  []     s     =     str  .  toCharArray  ();      smallestPalindrome  (  s  );   }   }   // This code is contributed    // by ChitraNayal   
Python 3
   # Python 3 program to get lexicographically    # smallest palindrome string   # Utility method to check str is    # possible palindrome after ignoring    def   isPossiblePalindrome  (  str  ):   n   =   len  (  str  )   for   i   in   range  (  n   //   2  ):   # If both left and right character    # are not dot and they are not    # equal also then it is not possible    # to make this string a palindrome    if   (  str  [  i  ]   !=   '.'   and   str  [  n   -   i   -   1  ]   !=   '.'   and   str  [  i  ]   !=   str  [  n   -   i   -   1  ]):   return   False   return   True   # Returns lexicographically smallest   # palindrome string if possible   def   smallestPalindrome  (  str  ):   if   (  not   isPossiblePalindrome  (  str  )):   return   'Not Possible'   n   =   len  (  str  )   str   =   list  (  str  )   # loop through character of string   for   i   in   range  (  n  ):   if   (  str  [  i  ]   ==   '.'  ):   # if one of character is dot    # replace dot with other character   if   (  str  [  n   -   i   -   1  ]   !=   '.'  ):   str  [  i  ]   =   str  [  n   -   i   -   1  ]   # if both character are dot    # then replace them with    # smallest character 'a'   else  :   str  [  i  ]   =   str  [  n   -   i   -   1  ]   =   'a'   # return the result   return   str   # Driver code   if   __name__   ==   '__main__'  :   str   =   'ab..e.c.a'   print  (  ''  .  join  (  smallestPalindrome  (  str  )))   # This code is contributed by ChitraNayal   
C#
   // C# program to get lexicographically    // smallest palindrome string   using     System  ;   public     class     GFG         {      // Utility method to check str is      // possible palindrome after ignoring      static     bool     isPossiblePalindrome  (  char     []  str  )      {      int     n     =     str  .  Length  ;      for     (  int     i     =     0  ;     i      <     n     /     2  ;     i  ++  )      {      /* If both left and right character     are not dot and they are not     equal also then it is not     possible to make this string a    palindrome */      if     (  str  [  i  ]     !=     '.'     &&      str  [  n     -     i     -     1  ]     !=     '.'     &&      str  [  i  ]     !=     str  [  n     -     i     -     1  ])      return     false  ;      }      return     true  ;      }      // Returns lexicographically smallest       // palindrome string if possible      static     void     smallestPalindrome  (  char     []  str  )      {      if     (  !  isPossiblePalindrome  (  str  ))      Console  .  WriteLine  (  'Not Possible'  );      int     n     =     str  .  Length  ;      // loop through character of string      for     (  int     i     =     0  ;     i      <     n  ;     i  ++  )      {      if     (  str  [  i  ]     ==     '.'  )      {      // if one of character is dot       // replace dot with other character      if     (  str  [  n     -     i     -     1  ]     !=     '.'  )      str  [  i  ]     =     str  [  n     -     i     -     1  ];      // if both character are dot       // then replace them with       // smallest character 'a'      else      str  [  i  ]     =     str  [  n     -     i     -     1  ]     =     'a'  ;      }      }      // return the result      for  (  int     i     =     0  ;     i      <     n  ;     i  ++  )      Console  .  Write  (  str  [  i  ]     +     ''  );      }      // Driver code      public     static     void     Main  ()      {      String     str     =     'ab..e.c.a'  ;      char  []     s     =     str  .  ToCharArray  ();      smallestPalindrome  (  s  );      }   }   // This code is contributed by PrinciRaj1992   
PHP
      // PHP program to get lexicographically   // smallest palindrome string   // Utility method to check str is   // possible palindrome after ignoring   function   isPossiblePalindrome  (  $str  )   {   $n   =   strlen  (  $str  );   for   (  $i   =   0  ;   $i    <   $n   /   2  ;   $i  ++  )   {   /* If both left and right     character are not dot and     they are not equal also then     it is not possible to make this     string a palindrome */   if   (  $str  [  $i  ]   !=   '.'   &&   $str  [  $n   -   $i   -   1  ]   !=   '.'   &&   $str  [  $i  ]   !=   $str  [  $n   -   $i   -   1  ])   return   false  ;   }   return   true  ;   }   // Returns lexicographically smallest    // palindrome string if possible   function   smallestPalindrome  (  $str  )   {   if   (  !  isPossiblePalindrome  (  $str  ))   return   'Not Possible'  ;   $n   =   strlen  (  $str  );   // loop through character of string   for   (  $i  =   0  ;   $i    <   $n  ;   $i  ++  )   {   if   (  $str  [  $i  ]   ==   '.'  )   {   // if one of character is dot    // replace dot with other character   if   (  $str  [  $n   -   $i   -   1  ]   !=   '.'  )   $str  [  $i  ]   =   $str  [  $n   -   $i   -   1  ];   // if both character are dot    // then replace them with    // smallest character 'a'   else   $str  [  $i  ]   =   $str  [  $n   -   $i   -   1  ]   =   'a'  ;   }   }   // return the result   return   $str  ;   }   // Driver code   $str   =   'ab..e.c.a'  ;   echo   smallestPalindrome  (  $str  );   // This code is contributed    // by ChitraNayal   ?>   
JavaScript
    <  script  >   // Javascript program to get lexicographically    // smallest palindrome string          // Utility method to check str is      // possible palindrome after ignoring      function     isPossiblePalindrome  (  str  )      {      let     n     =     str  .  length  ;      for     (  let     i     =     0  ;     i      <     Math  .  floor  (  n     /     2  );     i  ++  )      {      /* If both left and right character     are not dot and they are not     equal also then it is not     possible to make this string a    palindrome */      if     (  str  [  i  ]     !=     '.'     &&      str  [  n     -     i     -     1  ]     !=     '.'     &&      str  [  i  ]     !=     str  [  n     -     i     -     1  ])      return     false  ;      }          return     true  ;      }          // Returns lexicographically smallest       // palindrome string if possible      function     smallestPalindrome  (  str  )      {      if     (  !  isPossiblePalindrome  (  str  ))      document  .  write  (  'Not Possible'  );          let     n     =     str  .  length  ;          // loop through character of string      for     (  let     i     =     0  ;     i      <     n  ;     i  ++  )      {      if     (  str  [  i  ]     ==     '.'  )      {      // if one of character is dot       // replace dot with other character      if     (  str  [  n     -     i     -     1  ]     !=     '.'  )      str  [  i  ]     =     str  [  n     -     i     -     1  ];          // if both character are dot       // then replace them with       // smallest character 'a'      else      str  [  i  ]     =     str  [  n     -     i     -     1  ]     =     'a'  ;      }      }          // return the result      for  (  let     i     =     0  ;     i      <     n  ;     i  ++  )      document  .  write  (  str  [  i  ]     +     ''  );          }          // Driver code      let     str  =  'ab..e.c.a'  ;      let     s     =     str  .  split  (  ''  );      smallestPalindrome  (  s  );          // This code is contributed by rag2127        <  /script>   

Wyjście
abcaeacba 

Złożoność czasowa: O(n) gdzie n jest długością łańcucha.
Złożoność przestrzeni pomocniczej: O(1)