编写字符串反转函数strrev

论坛 期权论坛 脚本     
匿名网站用户   2020-12-20 11:24   84   0

问题
编写字符串反转函数:strrev。要求时间和空间效率都尽量高。测试用例:输入“abcd”,输出应为“dcba”;
解法1 遍历字符串,一头一尾交换
代码

char * strrev1(const char* str)
{
    int len = strlen(str);
    char* tmp = new char[len+1];
    strcpy(tmp,str);
    for(int i = 0;i<len/2;i++)
    {
        char c = tmp[i];
        tmp[i] = tmp[len-i-1];
        tmp[len-i-1] = c;
    }
    return tmp;
}

解法2 指针操作交换
代码

char *strrev2(const char *str)
{
    char *temp = new char[strlen(str)+1];
    strcpy(temp,str);
    char * ret = temp;
    char * p = temp+strlen(str)-1;
    while(p>temp)
    {
        char t = *temp;
        *temp = *p;
        *p = t;

        --p;
        ++temp;
    }
    return ret;
}

解法3 异或交换
代码

char *strrev3(const char * str)
{
    char * temp = new char[strlen(str)+1];
    strcpy(temp,str);
    char *ret=temp;
    char *p = temp+strlen(str)-1;

    while(p>temp)
    {
        *p^=*temp;
        *temp^=*p;
        *p^=*temp;

        --p;
        ++temp;
    }
    return ret;
}

解法4 加减法交换
代码

char *strrev4(const char * str)
{
    char * temp = new char[strlen(str)+1];
    strcpy(temp,str);
    char *ret=temp;
    char *p = temp+strlen(str)-1;

    while(p>temp)
    {
        *p =*p + *temp;
        *temp=*p - *temp;
        *p =*p - *temp;


        --p;
        ++temp;
    }
    return ret;
}

解法5 递归交换
代码

char *reverse5(char* str,int len)
{
    if(len<= 1)
        return str;
    char t = *str;
    *str = *(str+len-1);
    *(str+len-1) = t;
    return (reverse5(str+1,len-2)-1);
}
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:1136255
帖子:227251
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP