这篇文章主要介绍了使用C语言实现字符串逆序操作案例,本文包含使用C语言的两种方法去实现,递归和非递归,以下就是详细内容,需要的朋友可以参考下
编写一个函数 reverse_string(char * string)
实现:将参数字符串中的字符反向排列。
要求:不能使用C函数库中的字符串操作函数。
非递归实现:
#include //编写一个函数 reverse_string(char * string)(非递归实现) //实现:将参数字符串中的字符反向排列。 //要求:不能使用C函数库中的字符串操作函数。 //求字符串长度 int my_strlen(char* str) { int count = 0; while(*str != '\0') { count++; str++; } return count; } void reverse_string(char* str) { int left = 0; int right = my_strlen(str) - 1; while (left <right) { char temp = str[left]; str[left] = str[right]; str[right] = temp; left++; right--; } } int main() { char arr[] = "hellobit"; reverse_string(arr); printf("%s\n", arr); return 0; }
输出结果:
递归实现:
#include //编写一个函数 reverse_string(char * string) //实现:将参数字符串中的字符反向排列。 //要求:不能使用C函数库中的字符串操作函数。 //求字符串长度 int my_strlen(char* str) { int count = 0; while(*str != '\0') { count++; str++; } return count; } //递归实现 void reverse_string(char* str) { char temp = str[0]; int len = my_strlen(str); str[0] = str[len - 1]; str[len - 1] = '\0';//末尾置1方便计算字符串长度以及置换其他位 if (my_strlen(str)<b style="color:transparent">来源gao@!dai!ma.com搞$$代^@码网</b>>1) { reverse_string(str + 1); } str[len - 1] = temp;//将末尾置换 } int main() { char arr[] = "hellobit"; reverse_string(arr); printf("%s\n", arr); return 0; }
输出结果:
以上就是使用C语言实现字符串逆序操作案例的详细内容,更多请关注gaodaima搞代码网其它相关文章!