字符串反转函数 使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

字符串反转函数 使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法

  2021-03-18 我要评论
想了解使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法的相关内容吗,在本文为您仔细讲解字符串反转函数的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C语言,递归,非递归,下面大家一起来学习吧。

代码如下所示:

复制代码 代码如下:

// 递归实现字符串反转  
char *reverse(char *str)  
{  
 if( !str )  
 {  
  return NULL;
 }  

    int len = strlen(str);  
    if( len > 1 )  
    {  
        char ctemp =str[0];  
        str[0] = str[len-1];     
        str[len-1] = '/0';// 最后一个字符在下次递归时不再处理  
        reverse(str+1); // 递归调用  
        str[len-1] = ctemp;  
    }  

    return str;  
}

// 非递归实现字符串反转
char *reverse(char *str)  
{  
 if( !str )  
 {  
  return NULL;
 }  

    int len = strlen(str);  
    char temp;  
    for( int i = 0; i < len / 2; i++ )  
    {  
        // 交换前后两个相应位置的字符  
        temp = *(str + i);  
        *(str + i) = *(str + len - 1 - i);  
        *(str + len - 1 - i) = temp;  
    }  

    return str;  
}
int _tmain(int argc, _TCHAR* argv[])
{
 char src[] = {"abcdef"};
 char *pdest = reverse(src);
 getchar();
 return 0;
}

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们