字符串逆序总结

题目:接受一个字符串,然后输出该字符串反转后的字符串。比如s="abcd",逆序后变成s="dcba"。

这题比较简单,方法也有很多,这里简单总结一下,以供参考。

程序1-程序4都是比较基本的方法,程序5-程序8则是一些比较高级的方法。

程序1

#include 
#include

using namespace std;  
  
int main()  
{  
    string str,s = "";
	cin>>str;
	for(int i = 0;i
程序2

#include 
#include 
#include 
using namespace std;
 
int main(){
    string ss;
    while(getline(cin,ss)){
        reverse(ss.begin(),ss.end());
        cout<
程序3:

#include
using namespace std;
int main() {
    string str;
    getline(cin,str);
    int len = str.size();
    int i = 0;
    int j = len-1;
    while(i < j) {
        char temp = str[i];
        str[i] = str[j];
        str[j] = temp;
        i++;
        j--;
    }
    cout<
程序4:

#include
#include
using namespace std;
int main()
{
    string s1;
    while(getline(cin,s1))
    {
        for(int i=s1.length()-1;i>=0;i--)
         {
            cout<
程序5:
char* Reverse(char* s)
{
    //将q指向字符串最后一个字符
    char* q = s ;
    while( *q++ ) ;
    q -= 2 ; 

    //分配空间,存储逆序后的字符串。
    char* p = newchar[sizeof(char) * (q - s + 2)] ; 
    char* r = p ;

    // 逆序存储
    while(q >= s)
        *p++ = *q-- ;
    *p = '\0' ;

    return r ;
}
程序6: 原地逆序(in-place reverse)这是最常考的,原地逆序意味着不允额外分配空间,主要有以下几种方法,思想都差不多,就是将字符串两边的字符逐个交换,如下图。给定字符串"abcdef",逆序的过程分别是交换字符a和f,交换字符b和e,交换字符c和d。方法是设置两个指针,分别指向字符串的头部和尾部,然后交换两个指针所指的字符,并向中间移动指针直到交叉。

char* Reverse(char* s)
{
    // p指向字符串头部
    char* p = s ;

    // q指向字符串尾部
    char* q = s ;
    while( *q )
        ++q ;
    q -- ;

    // 交换并移动指针,直到p和q交叉
    while(q > p)
    {
        char t = *p ;
        *p++ = *q ;
        *q-- = t ;
    }

    return s ;
}
程序7:递归的方法

// 对字符串s在区间left和right之间进行逆序,递归法
void Reverse( char* s, int left, int right )
{
    if(left >= right)
        return;

    char t = s[left] ;
    s[left] = s[right] ;
    s[right] = t ;

    Reverse(s, left + 1, right - 1) ;
}
程序8:用异或操作

// 使用异或操作对字符串s进行逆序
char* Reverse(char* s)
{
    char* r = s ;
    //令p指向字符串最后一个字符
    char* p = s;
    while (*(p + 1) != '\0')
        ++p ;
    // 使用异或操作进行交换
    while (p > s)
    {
        *p = *p ^ *s ;
        *s = *p ^ *s ;
        *p = *p-- ^ *s++ ;
    }

    return r ;
}
拓展:按单词逆序

给定一个字符串,按单词将该字符串逆序,比如给定"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 ;
}

参考资料:

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

C++交换两个数总结

你可能感兴趣的:(C++)