概述
编写一个函数 reverse_string(char * string)
实现:将参数字符串中的字符反向排列。
要求:不能使用C函数库中的字符串操作函数。
非递归实现:
#include<stdio.h> //编写一个函数 reverse_string(char * string)(非递归实现) //实现:将参数字符串中的字符反向排列。 //要求:不能使用C函数库中的字符串操作函数。 //求字符串长度 int my_strlen(char* str) { int count = 0; while(*str != ' ') { 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("%sn", arr); return 0; }
输出结果:
递归实现:
#include<stdio.h> //编写一个函数 reverse_string(char * string) //实现:将参数字符串中的字符反向排列。 //要求:不能使用C函数库中的字符串操作函数。 //求字符串长度 int my_strlen(char* str) { int count = 0; while(*str != ' ') { 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] = ' ';//末尾置1方便计算字符串长度以及置换其他位 if (my_strlen(str)>1) { reverse_string(str + 1); } str[len - 1] = temp;//将末尾置换 } int main() { char arr[] = "hellobit"; reverse_string(arr); printf("%sn", arr); return 0; }
输出结果:
到此这篇关于使用C语言实现字符串逆序操作案例的文章就介绍到这了,更多相关C语言实现字符串逆序内容请搜索靠谱客以前的文章或继续浏览下面的相关文章希望大家以后多多支持靠谱客!
最后
以上就是矮小洋葱为你收集整理的使用C语言实现字符串逆序操作案例的全部内容,希望文章能够帮你解决使用C语言实现字符串逆序操作案例所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复