使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法_C语言教程-查字典教程网
使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法
使用C语言递归与非递归实现字符串反转函数char *reverse(char *str)的方法
发布时间:2016-12-28 来源:查字典编辑
摘要:代码如下所示:复制代码代码如下://递归实现字符串反转char*reverse(char*str){if(!str){returnNULL;...

代码如下所示:

复制代码 代码如下:

// 递归实现字符串反转

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;

}

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新C语言学习
    热门C语言学习
    编程开发子分类