字符串面试题(一)字符串逆序

来源:互联网 发布:后缀表达式c语言算法 编辑:程序博客网 时间:2024/05/19 01:07

二 用递归的方式,需要给定逆序的区间,调用方法:Reverse(s, 0, strlen(s)) ;

复制代码
// 对字符串s在区间left和right之间进行逆序,递归法void Reverse( char* s, int left, int right ){    if(left >= right)        return s ;    char t = s[left] ;    s[left] = s[right] ;    s[right] = t ;    Reverse(s, left + 1, right - 1) ;}
复制代码

三 非递归法,同样指定逆序区间,和方法一没有本质区别,一个使用指针,一个使用下标。

复制代码
// 对字符串str在区间left和right之间进行逆序char* Reverse( char* s, int left, int right ){    while( left < right )    {        char t = s[left] ;        s[left++] = s[right] ;        s[right--] = t ;    }    return s ;}
复制代码

按单词逆序

给定一个字符串,按单词将该字符串逆序,比如给定"This is a sentence",则输出是"sentence a is This",为了简化问题,字符串中不包含标点符号。

分两步

1 先按单词逆序得到"sihT si a ecnetnes"

2 再整个句子逆序得到"sentence a is This"

对于步骤一,关键是如何确定单词,这里以空格为单词的分界。当找到一个单词后,就可以使用上面讲过的方法将这个单词进行逆序,当所有的单词都逆序以后,将整个句子看做一个整体(即一个大的包含空格的单词)再逆序一次即可,如下图所示,第一行是原始字符换,第二行是按单词逆序后的字符串,最后一行是按整个句子逆序后的字符串。

代码

复制代码
// 对指针p和q之间的所有字符逆序void ReverseWord(char* p, char* q){    while(p < q)    {        char t = *p ;        *p++ = *q ;        *q-- = t ;    }}// 将句子按单词逆序char* ReverseSentence(char* s){    // 这两个指针用来确定一个单词的首尾边界    char* p = s ; // 指向单词的首字符    char* q = s ; // 指向空格或者 '\0'    while(*q != '\0')    {        if (*q == '')        {            ReverseWord(p, q - 1) ;            q++ ; // 指向下一个单词首字符            p = q ;        }        else            q++ ;    }    ReverseWord(p, q - 1) ; // 对最后一个单词逆序    ReverseWord(s, q - 1) ; // 对整个句子逆序    return s ;}

原创粉丝点击