标签:arr reverse string 递归 int len char 字符串 逆序
编写一个函数 reverse_string(char * string)(递归实现)
实现:将参数字符串中的字符反向排列,不是逆序打印。
要求:不能使用C函数库中的字符串操作函数。
比如:
char arr[] = "abcdef";
逆序之后数组的内容变成:fedcba
代码实现如下:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int my_strlen(char* p)
{
if (*p != '\0')
{
return 1 + my_strlen(p + 1);
}
else
return 0;
}
void reverse_string(char* arr,int len)
{
if (len>=2)
{
int temp = arr[0];
arr[0] = arr[len-1];
arr[len-1] = temp;
len-=2;
reverse_string(arr+1,len);
}
}
int main()
{
char arr[] = "abcdef";
int len = my_strlen(arr);
reverse_string(arr,len);
printf("交换后:%s\n", arr);
return 0;
}
标签:arr,reverse,string,递归,int,len,char,字符串,逆序 来源: https://blog.csdn.net/weixin_61700539/article/details/121128082
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。