字符串逆置

本文介绍了使用C语言及C++实现字符串逆置的四种不同方法,包括使用额外数组、原地逆置、通过函数逆置以及C++标准库算法。每种方法都提供了详细的代码示例。

记录一下字符串逆置的代码:


此版用到了另一个字符数组,以保存逆置后的结果,开始时只是定义了两个字符指针来保存输入的字符串,编译总是失败,看了一下《C语言实用教程》里面说到,char *p  scanf("%s",p);这种定义方式是错误的,指针需要先指向一个地址。于是就定义了两个字符数组来保存结果。这样定义一个常量N为50,但是感觉缺少了一些灵活性。

#include <stdio.h>
#define N 50

int main()
{
    int i, n=0;
    //char *str1, *str2;
    char str1[N], str2[N];
    char *p=str1;
    printf("Please input the string:");
    scanf("%s",str1);
    printf("The string you input is %s\n",str1);
    while(*p!='\0')
    {
                      ++p;
                      ++n;
    }
    for(i=0;i<n;++i)
        str2[i]=*--p;
        //printf("%c",*--str1);
    str2[i]='\0';
    printf("The string reversed is %s\n",str2);
    
    return 0;
}


下面的版本是在一个字符串内部进行逆置,利用一个临时变量temp保存字符。

#include <stdio.h>
#include <string.h>
#define N 50

int main()
{
    int i,n;
    char str[N], temp;
    printf("Please input the string:");
    scanf("%s",str);
    printf("The string you input is %s\n",str);
    n=strlen(str);
    for(i=0;i<n/2;++i)
    {
                      temp=str[i];
                      str[i]=str[n-1-i];
                      str[n-1-i]=temp;
    }
    printf("The string reversed is %s\n",str);
    
    return 0;
} 

下面的版本将字符逆置写成一个函数。几天前看到优快云论坛上的一个问题:定义一个函数 void strcpy(char *to, const char *from)反转字符串要求函数不可以用到库函数和其他变量,于是只针对to和from指针做操作,在反向遍历时用while做条件判断(不知道字符串第一个字符的前一个字符是什么,也许是NULL?),结果有一些问题。可以利用数组首地址调入函数直接操作。
#include <stdio.h>
#define N 50

//reverse copy
void strcpy(char *to,const char *from)
{
     while(*++from)
     ;
     while(*to++=*--from)
     ;
     while(*--to)
     ;
     ++to;
}

int main()
{
    char str1[N], str2[N];
    //char *p1=str1, *p2=str2;
    printf("Please input the string:");
    scanf("%s",str1);
    printf("The string you input is %s\n",str1);
    //strcpy(p2, p1);
    strcpy(str2,str1);
    printf("The string reversed is %s\n",str2);
    
    return 0;
}


最后是一个C++的版本,受到网上一个思路的启发,在C++的算法库中有一个反转算法,只要传入迭代器参数即可,而且利用string库中的getline()函数可以实现带有空格字符串的逆置,非常之简洁。

#include <iostream>
#include <string>
//#include <iterator>
#include <algorithm>

using namespace std;

int main()
{
    string str;
    cout<<"Please input a string you want to reverse:"<<endl;
    getline(cin,str);
    //string::iterator beg=str.begin();
    //string::iterator end=str.end();
    reverse(str.begin(),str.end());
    cout<<"The string reversed is:"<<str<<endl;
    
    return 0; 
}

### C++ 中字符串的实现方法 在 C++ 编程语言中,可以使用多种方式来实现字符串操作。以下是几种常见的方法: #### 方法一:使用标准库函数 `std::reverse` C++ 提供了一个非常方便的标准库函数 `std::reverse` 来反转容器中的元素,包括字符串。此函数位于头文件 `<algorithm>` 中。 ```cpp #include <iostream> #include <string> #include <algorithm> int main() { std::string str = "hello world"; std::reverse(str.begin(), str.end()); std::cout << "Reversed String: " << str << std::endl; return 0; } ``` 上述代码通过调用 `std::reverse` 函数实现了字符串[^1]。 --- #### 方法二:手动实现字符串逻辑 如果不想依赖标准库函数,可以通过遍历字符串并交换首尾字符的方式手动实现字符串功能。 ```cpp #include <iostream> #include <string> void reverseString(std::string& s) { int n = s.length(); for (int i = 0; i < n / 2; ++i) { char temp = s[i]; s[i] = s[n - i - 1]; s[n - i - 1] = temp; } } int main() { std::string str = "hello world"; reverseString(str); std::cout << "Reversed String: " << str << std::endl; return 0; } ``` 这种方法的核心在于利用双指针技术逐一交换字符串两端的字符,从而完成过程[^2]。 --- #### 方法三:基于临时数组的字符串 另一种思路是创建一个临时数组存储原字符串的内容,并按照倒序将其重新拼接成新的字符串。这种方式通常适用于某些特定场景下的需求。 ```cpp #include <iostream> #include <cstring> // strcpy 和 strcat 的声明在此头文件中 void reverseUsingTempArray(const char* input, char* output) { int length = strlen(input); for (int i = 0; i < length; ++i) { output[length - 1 - i] = input[i]; } output[length] = '\0'; // 添加字符串结束标志符 } int main() { const char* original = "hello world"; char reversed[strlen(original) + 1]; // 额外空间用于存放'\0' reverseUsingTempArray(original, reversed); std::cout << "Reversed String: " << reversed << std::endl; return 0; } ``` 这种方案虽然简单易懂,但在实际开发中较少被采用,因为其效率较低且容易引入额外错误风险[^3]。 --- ### 总结 以上介绍了三种不同的字符串方法,分别是利用标准库函数 `std::reverse`、手写循环逻辑以及借助临时数组的方式来解决问题。其中推荐优先考虑第一种方法——即直接运用 STL 提供的功能接口,因为它不仅简洁高效而且具有良好的可维护性和跨平台兼容性特点。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值