其他
C基础、经典:字符串逆序
分享一道经典的C语言题目。
题目:
字符串逆序。如:hello world
转换为dlrow olleh
。
流程图:
代码:
左右滑动查看全部代码>>>
/*
- 程序功能: 字符串反转
- 作者:ZhengN
- 公众号:嵌入式大杂烩
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* 交换两数函数选择 */
#define FUNC_CHIOCE 1 // 1:方法一 2:方法二 3:方法三
/* 交换两数函数 */
#if (FUNC_CHIOCE == 1) // 方法一:普通方法
void change_ab(char *a, char *b)
{
int temp = 0;
temp = *a;
*a = *b;
*b = temp;
}
#elif(FUNC_CHIOCE == 2) // 方法二:采用算术的方法
void change_ab(char *a, char *b)
{
*a = *a + *b;
*b = *a - *b;
*a = *a - *b;
}
#else // 方法三:采用异或的方法(较好的方法)
void change_ab(char *a, char *b)
{
*a = *a ^ *b;
*b = *a ^ *b;
*a = *a ^ *b;
}
#endif
/* 字符串反转函数 */
char *str_reverse(char* src_str)
{
int str_len = strlen(src_str);
char *dest_str = src_str;
char *pHead = &src_str[0]; // 指向字符串的头
char *pTail = &src_str[str_len -1]; // 指向字符串的尾
while ((pHead != pTail) && (pHead < pTail))
{
change_ab(pHead, pTail); // 交换头尾字符
pHead++; // 指向头部的指针往后移
pTail--; // 指向尾部的指针往前移
}
return dest_str;
}
/* 主函数 */
int main(void)
{
char src_str[] = "hello world";
char *dest_str = (char*)malloc(strlen(src_str));
printf("Before reverse: %s\n", src_str);
strcpy(dest_str, str_reverse(src_str));
printf("After reverse: %s\n", dest_str);
free(dest_str);
dest_str = NULL;
return 0;
}
这里有用到交换数据的函数。提供了三种方法,三种方法优劣看往期笔记:《C基础、经典:交换a、b值较好的方法?》
运行结果:
猜你喜欢
1024G 嵌入式资源大放送!包括但不限于C/C++、单片机、Linux等。在公众号聊天界面回复1024,即可免费获取!
Modified on