zoukankan      html  css  js  c++  java
  • 字符串逆序打印

    版本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
    ",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
    ",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 == '')
        {
            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
    ",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 == '')
        {
            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
    ",g_buf);
        return 0;
    }
  • 相关阅读:
    利用rqalpha完成一个股指期货的回测(二) 分钟数据获取和转换
    利用rqalpha完成一个股指期货的回测(一)
    Pandas
    SAR停损指标
    一些简单的指标
    协程--流畅的Python第16章读书笔记
    python初级(302) 8 列表(选择排序练习二)
    博客已转移至 http://blog.yemou.net/
    将博客搬至51CTO
    将博客搬至CSDN
  • 原文地址:https://www.cnblogs.com/wanghao-boke/p/11604871.html
Copyright © 2011-2022 走看看