目录分析代码实现网上参考总结分析 在第18天:利用递归函数调用方式,将所输入的字符以相反顺序打印出来中,已经用过递归实现字符顺序输入,逆序输出,今天的题目是字符串反转,将以字符数组的
在第18天:利用递归函数调用方式,将所输入的字符以相反顺序打印出来中,已经用过递归实现字符顺序输入,逆序输出,今天的题目是字符串反转,将以字符数组的形式来进行操作。
#include <stdio.h>
#include <string.h>
#define MAX_LENGTH 50 //最大长度
char *String_Invertion(char *str);
int main()
{
char string[MAX_LENGTH];
printf("请输入一个字符串\n");
scanf("%s", string);
String_Invertion(string);
printf("反转后的字符串为%s\n", string);
return 0;
}
char *String_Invertion(char *str)
{
if(str == NULL)
return NULL;
int len = strlen(str);
int i = 0;
for(i = 0; i < len / 2; i++) //替换len/2次
{
str[i] = str[i] ^ str[len - 1 - i];
str[len - 1 - i] = str[i] ^ str[len - 1 - i];
str[i] = str[i] ^ str[len - 1 - i];
}
return str;
}
运行结果
// Created by www.runoob.com on 15/11/9.
// Copyright © 2015年 菜鸟教程. All rights reserved.
//
#include <stdio.h>
void reverse(char* s)
{
// 获取字符串长度
int len = 0;
char* p = s;
while (*p != 0)
{
len++;
p++;
}
// 交换 ...
int i = 0;
char c;
while (i <= len / 2 - 1)
{
c = *(s + i);
*(s + i) = *(s + len - 1 - i);
*(s + len - 1 - i) = c;
i++;
}
}
int main()
{
char s[] = "www.runoob.com";
printf("'%s' =>\n", s);
reverse(s); // 反转字符串
printf("'%s'\n", s);
return 0;
}
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!
--结束END--
本文标题: C语言每日练习之字符串反转
本文链接: https://www.lsjlt.com/news/157051.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0