编写一个函数 reverse_string(char * string)
实现:将参数字符串中的字符反向排列。
要求:不能使用C函数库中的字符串操作函数。
非递归实现:
#include<stdio.h> //编写一个函数 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<stdio.h> //编写一个函数 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)>1) { reverse_string(str + 1); } str[len - 1] = temp;//将末尾置换 } int main() { char arr[] = "hellobit"; reverse_string(arr); printf("%s\n", arr); return 0; }
输出结果:
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)