Code: Search a Reverse Substring

简介:

 You are given a String input. You are to find the longest substring of input such that the reversal of the substring is also a substring of input. In case of a tie, return the string that occurs earliest in input.

Notes 
    -The substring and its reversal may overlap partially or completely. 
    -The entire original string is itself a valid substring (see example 4).
Constraints 
    -input will contain between 1 and 50 characters, inclusive. 
    -Each character of input will be an uppercase letter ('A'-'Z').
Examples
0) "XBCDEFYWFEDCBZ" 
    Returns: "BCDEF" 
    We see that the reverse of BCDEF is FEDCB, which appears later in the string.
1) "XYZ" 
    Returns: "X" 
    The best we can do is find a one character substring, so we implement the tie-breaker rule of taking the earliest one first.
2) "ABCABA" 
    Returns: "ABA" 
    The string ABA is a palindrome (it's its own reversal), so it meets the criteria.
3) "FDASJKUREKJFDFASIREYUFDHSAJYIREWQ" 
    Returns: "FDF"
    The similar as above.
4) "ABCDCBA" 
    Returns: "ABCDCBA" 
    Here, the entire string is its own reversal.

None.gifclass  ReverseSubstring
ExpandedBlockStart.gifContractedBlock.gifdot.gif
{
InBlock.gif    static void Main(string
[] args)
ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif
{
ExpandedSubBlockStart.gifContractedSubBlock.gif        string[] strings = new string[] dot.gif
{ "XBCDEFYWFEDCBZ", "XYZ"
ExpandedSubBlockEnd.gif                "FDASJKUREKJFDFASIREYUFDHSAJYIREWQ", "ABCDCBA" }
;
InBlock.gif        for ( int i=0 ; i < strings.Length ; ++
i )
ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif
{
InBlock.gif            System.Console.WriteLine(FindReversed(strings[i]));
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }
InBlock.gif
InBlock.gif    
private static string FindReversed(string  input)
ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif
{
InBlock.gif        string substring = string
.Empty;
InBlock.gif        for ( int i=0 ; i < input.Length ; ++
i )
ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif
{
InBlock.gif            for ( int j=0 ; j < input.Length ; ++
j )
ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif
{
InBlock.gif                if ( input[i] == input[input.Length-1-
j] )
ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif
{
InBlock.gif                    if ( i == input.Length-1-
j )
ExpandedSubBlockStart.gifContractedSubBlock.gif                    dot.gif
{
InBlock.gif                        if ( substring.Length == 0
 )
ExpandedSubBlockStart.gifContractedSubBlock.gif                        dot.gif
{
InBlock.gif                            substring =
 input[i].ToString();
ExpandedSubBlockEnd.gif                        }

InBlock.gif                         break ;
ExpandedSubBlockEnd.gif                    }

InBlock.gif                     else
ExpandedSubBlockStart.gifContractedSubBlock.gif                     dot.gif {
InBlock.gif                        int k = 0
;
InBlock.gif                        for ( ; k < input.Length-i-j ; ++
k )
ExpandedSubBlockStart.gifContractedSubBlock.gif                        dot.gif
{
InBlock.gif                            if ( input[i+k] != input[input.Length-1-j-k] ) break
;
ExpandedSubBlockEnd.gif                        }

InBlock.gif                        if ( substring.Length <  k )
ExpandedSubBlockStart.gifContractedSubBlock.gif                        dot.gif
{
InBlock.gif                            substring =
 input.Substring(i, k);
ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }
ExpandedSubBlockEnd.gif                }
ExpandedSubBlockEnd.gif            }
ExpandedSubBlockEnd.gif        }
InBlock.gif         return  substring;
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

Results are:
None.gif BCDEF
None.gifX
None.gifABA
None.gifFDF
None.gifABCDCBA

本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

目录
相关文章
|
索引
ES6——find()、findindex()、indexof、includes()以及some
find()、findindex()、indexof、includes()以及some
73 0
LeetCode 415. Add Strings
给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和。
65 0
LeetCode 415. Add Strings
|
算法 容器
常用查找算法 find() find_if() adjacent_find() binary_search() count() count_if()
常用查找算法 find() find_if() adjacent_find() binary_search() count() count_if()
|
Python
Leetcode-Easy 989. Add to Array-Form of Integer
Leetcode-Easy 989. Add to Array-Form of Integer
111 0
|
JavaScript Windows 移动开发
|
机器学习/深度学习 人工智能