用递归思想实现字符串反转

#include<stdio.h>
#include<string.h>
char *reverse(char *str)   
{   
	if(!*str)   
	{   
	  return NULL;
	} 
	if(strlen(str)==1)
	{
	 return str;
	}
	char ctemp;
    int len = strlen(str);   
    if( len > 1 )   
    {   
        ctemp =str[0];   
        str[0] = str[len-1];  //创建临时变量并且对原有的字符进行压栈操作   
        str[len-1] ='\0';
        reverse(str+1);    //调用递归函数
    }  
       str[len-1] = ctemp;   
    return str;   	
}
int main()
{    
 char src[] = {"abcdefg"};
 printf("%s\n",reverse(src));
 return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值