首页 > 编程语言 > 详细

字符串逆序函数-- c语言

时间:2019-11-01 21:58:51      阅读:70      评论:0      收藏:0      [点我收藏+]

目前有两种思路,一个是申请一片辅助空间,然后将原字符串逆向拷贝到辅助空间,然后输出;

另一种是原地逆序,不需要额外的辅助空间,方法就是字符串首尾交换。

#include <stdio.h>
#include <string.h>
char* str_reverse(char* str)   //字符指针
{
    int n = strlen(str) / 2;
    int i = 0;
    char tmp = 0;
    for (i = 0; i < n; i++)
    {
        tmp = str[i];
        str[i] = str[strlen(str) - i - 1];   //对调
        str[strlen(str) - i - 1] = tmp;     
    }
    return str;
}
int main()
{
    char s[] = "hello world!";
    printf("str_reverse(s) = %s\n", str_reverse(s));
    return 0;
}

或利用指针特性,直接利用参数,代码如下:

#include <stdio.h>
#include <string.h>
void str_reverse(char* str)   //字符指针
{
    int n = strlen(str) / 2;
    int i = 0;
    char tmp = 0;
    for (i = 0; i < n; i++)
    {
        tmp = str[i];
        str[i] = str[strlen(str) - i - 1];   //对调
        str[strlen(str) - i - 1] = tmp;     
    }
    return str;
}
int main()
{
    char s[] = "hello world!";
    str_reverse(s);
    printf("str_reverse(s) = %s\n",s );
    return 0;
}

from: https://www.cnblogs.com/lvonve/

 

字符串逆序函数-- c语言

原文:https://www.cnblogs.com/imhuanxi/p/11779785.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!