字符串逆序打印

版本1 两个指针从头到尾和从尾到头交换内容逆序

/***
str_reverse.c
***/
#include<stdio.h>
#include<string.h>

int main()
{
    char buf[] = "abcdrfg";

    int len = strlen(buf);
    char *p1 = buf;
    char *p2 = buf + len - 1;

    while(p1 < p2)
    {
        char c = *p1;
        *p1 = *p2;
        *p2 = c;
        ++p1;
        --p2;
    }

    printf("buf = %s\n",buf);
    return 0; 
}

版本2

使用函数接口封装

/***
str_reverse.c
***/

#include<stdio.h>
#include<string.h>

int my_reverse(char *str)
{
    int iRet = -1;
    if(NULL == str)
    {
        return iRet;    
    }
   
    char *buf = str;
    int len = strlen(buf);
    char *p1 = buf;
    char *p2 = buf + len - 1;

    while(p1 < p2)
    {
        char c = *p1;
        *p1 = *p2;
        *p2 = c;
        ++p1;
        --p2;
    }

}

int main()
{
    char buf[] = "abcdrfg";
    my_reverse(buf);

    printf("buf = %s\n",buf);
    return 0; 
}

版本三

使用栈特性将字符串存储到全局变量中

/***
str_reverse.c
***/

#include<stdio.h>
#include<string.h>

char g_buf[256];

void reverse(char *p)
{
    if(NULL == p)
    {
        return ;
    }
    if(*p == '\0')
    {
        return;
    }

    reverse(p+1);
    strncat(g_buf,p,1);
}

int main()
{
    char buf[] = "abcd";
    memset(g_buf,0,sizeof(g_buf));
    reverse(buf);
    printf("g_buf = %s\n",g_buf);
    return 0;
}

版本4

使用栈将字符串存到传入的局部变量中

/***
str_reverse.c
***/

#include<stdio.h>
#include<string.h>

char g_buf[256];

void reverse(char *p)
{
    if(NULL == p)
    {
        return ;
    }
    if(*p == '\0')
    {
        return;
    }

    reverse(p+1);
    strncat(g_buf,p,1);
}

int main()
{
    char buf[] = "abcd";
    memset(g_buf,0,sizeof(g_buf));
    reverse(buf);
    printf("g_buf = %s\n",g_buf);
    return 0;
}

 

转载于:https://www.cnblogs.com/wanghao-boke/p/11604871.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值