方法一:
int my_strlen(char* arr){
if (*arr != '\0'){
return 1 + my_strlen(arr + 1);
}
else return 0;
}
#include<stdio.h>
void reverse_string(char arr[]){
int left = 0;
int right = my_strlen(arr)-1;//调用的求字符串长度函数
while (left < right){
int temp = arr[left];
arr[left] = arr[right];
arr[right] = temp;
left++;
right--;
}
}
int main(){
char arr[10] = "abcdefg";
//int sz = sizeof(string) / sizeof(string[0]);
reverse_string(arr);
printf("%s", arr);
return 0;
}
方法二:用递归
void reverse_string(char* arr){
int tmp = arr[0];//把第一个元素放到tmp中,
int len = my_strlen(arr);//求字符串长度
arr[0] = arr[len - 1];//把最末的元素放到第一个arr【0】
arr[len - 1] = '\0'; //给最末的元素赋'\0'
if (my_strlen(arr+1) >= 2)//递归到最后可能还剩1个或0个元素这个
//字符串是否为是1或0;是1或0就不用交换了
reverse_string(arr + 1);
arr[len - 1] = tmp;//把tmp中第一个元素的值给最后1个元素
}
int main(){
char arr[10] = "abcdefg";
//int sz = sizeof(string) / sizeof(string[0]);
reverse_string(arr);
printf("%s", arr);
return 0;
}
简短说明