字符串逆序可以说是最经常考的题目。这是一道入门级的题目,相信80%的程序员经历过这道题。给定一个字符串s,将s中的字符顺序颠倒过来,比如s="abcd",逆序后变成s="dcba"。

普通逆序

基本上没有这么考的,放在这里主要是为了和后面的原地逆序做个对比。很简单,直接分配一个与原字符串等长的字符数组,然后反向拷贝一下即可。

char* Reverse(char* s)
{//将q指向字符串最后一个字符char* q = s ;while( *q++ ) ;q -= 2 ; //分配空间,存储逆序后的字符串。char* p = newchar[sizeof(char) * (q - s + 2)] ; char* r = p ;// 逆序存储while(q >= s)*p++ = *q-- ;*p = '\0' ;return r ;
}

原地逆序

英文叫做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 s ;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 ;
}

不允许临时变量的原地逆序

使用异或操作

// 使用异或操作对字符串s进行逆序
char* Reverse(char* s)
{char* r = s ;//令p指向字符串最后一个字符char* p = s;while (*(p + 1) != '\0')++p ;// 使用异或操作进行交换while (p > s){*p = *p ^ *s ;*s = *p ^ *s ;*p = *p-- ^ *s++ ;}return r ;
}

按单词逆序

给定一个字符串,按单词将该字符串逆序,比如给定"This is a sentence",则输出是"sentence a is This",为了简化问题,字符串中不包含标点符号。

分两步

1 先按单词逆序得到"sihT si a ecnetnes"

2 再整个句子逆序得到"sentence a is This"

对于步骤一,关键是如何确定单词,这里以空格为单词的分界。当找到一个单词后,就可以使用上面讲过的方法将这个单词进行逆序,当所有的单词都逆序以后,将整个句子看做一个整体(即一个大的包含空格的单词)再逆序一次即可,如下图所示,第一行是原始字符换,第二行是按单词逆序后的字符串,最后一行是按整个句子逆序后的字符串。

代码

// 对指针p和q之间的所有字符逆序
void ReverseWord(char* p, char* q)
{while(p < q){char t = *p ;*p++ = *q ;*q-- = t ;}
}// 将句子按单词逆序
char* ReverseSentence(char* s)
{// 这两个指针用来确定一个单词的首尾边界char* p = s ; // 指向单词的首字符char* q = s ; // 指向空格或者 '\0'while(*q != '\0'){if (*q == ''){ReverseWord(p, q - 1) ;q++ ; // 指向下一个单词首字符p = q ;}elseq++ ;}ReverseWord(p, q - 1) ; // 对最后一个单词逆序ReverseWord(s, q - 1) ; // 对整个句子逆序return s ;
}

逆序打印

还有一类题目是要求逆序输出,而不要求真正的逆序存储。这题很简单,有下面几种方法,有的方法效率不高,这里仅是提供一个思路而已。

先求出字符串长度,然后反向遍历即可。

void ReversePrint(const char* s)
{
    int len = strlen(s) ;
    for (int i = len - 1; i >= 0; --i)
        cout << s[i];
}

如果不想求字符串的长度,可以先遍历到末尾,然后在遍历回来,这要借助字符串的结束符'\0

void ReversePrint(const char* s)
{const char* p = s ;while (*p)*p++ ;--p ; //while结束时,p指向'\0',这里让p指向最后一个字符while (p >= s){cout <<*p ;--p ;}
}

对于上面第二种方法,也可以使用递归的方式完成。

void ReversePrint(const char* s)
{
    if(*(s +1) != '\0')
        ReversePrint(s + 1) ;
    cout << *s ;
}
FROM: http://www.cnblogs.com/graphics/archive/2011/03/09/1977717.html

字符串面试题(一)字符串逆序相关推荐

  1. 字符串按照单词为单位逆序排列

    我们前面已经写过一个简单字符串逆序排序的方法,这里再开一个字符串排序问题: 给定一个字符串"I love China",编写程序完成以单词为单位的逆序,如"China l ...

  2. 将字符串“I am a student.”逆序输出为“student. a am I”

    给到一串字符"I am a student.",将其输出为"student. a am I". 整体思路为先将整个字符串逆序为 ''.tneduts a ma ...

  3. c语言单链表_C语言笔试题—单链表逆序

    前情回顾 之前更多的是给大家推荐的是好用的软件,经过反思之后觉得这些东西并不是我想要的,所以从今天开始我要转变方向了,更多的往我的专业方向去发展(虽然我是个小白),当然如果有说的不对的地方,希望大家能 ...

  4. 每天一道LeetCode-----以单词为单位逆序字符串,每个单词之间以一个空格分隔(原字符串中可能有多个空格)

    Reverse Words in a String 原题链接Reverse Words in a String 将字符串以单词为单位逆序,每个单词之间以一个空格间隔(原字符串中可能有多个空格) 逆序的 ...

  5. 信息学奥赛一本通 1162:字符串逆序

    [题目链接] ybt 1162:字符串逆序 [题目考点] 1. 字符串 2. 递归 [解题思路] 先去掉字符串末尾的'!' 递归输出逆序字符串 递归问题:输出字符串s的逆序字符串 递归关系:设字符串s ...

  6. 7-53 字符串逆序 (10 分)

    7-53 字符串逆序 (10 分) 将一个字符串中的字符逆序存放.如字符串为"abcde",则逆序存放后应为"edcba". 输入格式: 在一行中输入一个长度不 ...

  7. 1909 字符串逆序(函数专题)

    题目描述 写一个函数, 使输入的一个字符串按反序存放,在主函数中输入和输出字符串 void reverse(char str[]) { } 输入 输入一个字符串 输出 输出他的逆序 样例输入 i ca ...

  8. C语言——字符串逆序输出

    [问题描述]将输入的字符串逆序输出 [输入形式]要求输入一个字符串 [输出形式]逆序后输出 [样例输入]abcd [样例输出]dcba #include <stdio.h> #includ ...

  9. 字符串逆序 - 多种方法实现

    字符串逆序实现方法 1. 借助额外数组 2. 循环实现 2.1 图解 2.2 思路 2.3 代码实现 3. 递归实现1 4. 递归实现2 4.1 思路 对字符串进行逆序,以字符串abcdef为例 1. ...

  10. C语言 逆序输出字符串

    前言 逆序输出字符串最可能先想到的是遍历时用栈保存字符,最后出栈.既然栈可以实现,那我们也可以用递归的方法来实现,并且一定会比较简单. 除了以上两种,还可以对字符串进行原地逆置,最后再将该字符串输出即 ...

最新文章

  1. 服务器虚拟化组网方案,服务器虚拟化部署方案计划.doc
  2. 为什么redis是单线程的以及为什么这么快?
  3. 网络营销的探索与爆发
  4. BookMarklet:瑞士军刀你用了吗?
  5. my CSAPP Attack lab堆栈详解
  6. React后台管理系统-登录页面
  7. 串口数据波形显示_【专题教程第6期】SEGGER的J-Scope波形上位机软件,RTT模式波形上传可飙到500KB/S...
  8. python延时队列_如何通过Python实现RabbitMQ延迟队列
  9. 荒岛余生最后一个包裹_从《荒岛余生》看上世纪九十年代美国社会主流价值观...
  10. ajax请求到参数太大获取参数失败问题,Ajax请求参数较长导致请求失败
  11. C - Copying Books (POJ - 1505)
  12. gd库多点画图 php_用 PHP 实现身份证号码识别
  13. MTK6589平台——“长按powerkey重启”feature不工作问题的解决
  14. Ques核心思想——CSS Namespace
  15. 计算机视觉数据集大全 - Part1
  16. Sample Science 909 Lab for Mac - 909鼓声虚拟乐器
  17. win7 Host 与virtualbox 中的 ubuntu 11.04 共享文件夹
  18. 【OpenCV入门教程之一】 安装OpenCV:OpenCV 3.0、OpenCV 2.4.8、OpenCV 2.4.9 +VS 开发环境配置
  19. 反问疑问_反问疑问句的用法
  20. UWA 技术分享连载 转载

热门文章

  1. 关于打开新链接,用当前页还是用新页面?
  2. 利用JS判断是手机端还是PC端 浏览网站
  3. 细数技术指标-[转载]
  4. int与string转换
  5. Android环境搭建和Android HelloWorld—Android开发环境搭建
  6. IE8下的VML显示问题解决方案
  7. usaco Shaping Regions
  8. usaco wormhole(看了官方视频题解)
  9. 自走棋电脑版_2019年的爆款自走棋玩法,百花齐放过后,却身陷“变现烦恼”...
  10. php分页显示页数代码,php-Codeigniter分页显示结果数和页数