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

    原地逆序

    英文叫做in-place reverse。这是最常考的,原地逆序意味着不允额外分配空间,主要有以下几种方法,思想都差不多,就是将字符串两边的字符逐个交换,如下图。给定字符串"abcdef",逆序的过程分别是交换字符a和f,交换字符b和e,交换字符c和d。

    一 设置两个指针,分别指向字符串的头部和尾部,然后交换两个指针所指的字符,并向中间移动指针直到交叉。

    复制代码
    char* Reverse(char* s)
    {
        // p指向字符串头部
        char* p = s ;
    
        // q指向字符串尾部
        char* q = s ;
        while( *q )
            ++q ;
        q -- ;
    
        // 交换并移动指针,直到p和q交叉
        while(q > p)
        {
            char t = *p ;
            *p++ = *q ;
            *q-- = t ;
        }
    
        return s ;
    }
    复制代码

    二 用递归的方式,需要给定逆序的区间,调用方法:Reverse(s, 0, strlen(s)) ;

    复制代码
    // 对字符串s在区间left和right之间进行逆序,递归法
    void Reverse( char* s, int left, int right )
    {
        if(left >= right)
            return;
    
        char t = s[left] ;
        s[left] = s[right] ;
        s[right] = t ;
    
        Reverse(s, left + 1, right - 1) ;
    }
    复制代码

    三 非递归法,同样指定逆序区间,和方法一没有本质区别,一个使用指针,一个使用下标。

    复制代码
    // 对字符串str在区间left和right之间进行逆序
    char* Reverse( char* s, int left, int right )
    {
        while( left < right )
        {
            char t = s[left] ;
            s[left++] = s[right] ;
            s[right--] = t ;
        }
    
        return s ;
    }
    复制代码
  • 相关阅读:
    SQL查询
    SQL总结(二)连表查询
    SQL总结(一)基本查询
    SQL游标、函数的使用方法
    理解 Virtual DOM(摘)及评价
    virtual DOM的作用:将DOM的维护工作由系统维护转交给virtual DOM维护
    DOM的回流和重绘(重排、重绘)
    并发编程的核心
    执行流(指令流)的控制层级
    go语言的工资好高
  • 原文地址:https://www.cnblogs.com/tianlangshu/p/5205569.html
Copyright © 2011-2022 走看看