本篇内容介绍了“如何使用C语言实现字符串逆序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
编写一个函数 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("%s
", 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("%s
", arr);
return 0;
}
输出结果:
“如何使用C语言实现字符串逆序”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!