吴军《谷歌面试题:倒置英文句子》

举报
howard2005 发表于 2021/11/19 01:59:01 2021/11/19
【摘要】 吴军《谷歌面试题:倒置英文句子》 问题是这么说的:给你一个英语的语句,比如"London bridge is falling down",把它完全倒装过来,“down falling is bridge...

吴军《谷歌面试题:倒置英文句子》

问题是这么说的:给你一个英语的语句,比如"London bridge is falling down",把它完全倒装过来,“down falling is bridge London”,如何不使用额外的存储空间完成这个倒装过程?

通常学习计算机算法的人在解决这个问题时,首先会想到把这个句子切割成一个个单词,然后把它们存到一个数组里,数组的结构大致如下:
在这里插入图片描述
把这个数组顺序存入,逆序取出来就可以完成语句倒装的问题。当然,还有一个类似的办法,就是把上面的单词,一个个送入堆栈,记得堆栈的先进后出,后进先出性质,就可以利用这个数据结构完成句子的倒装。

但是,这种算法要额外地使用存储空间,因此不符合题目的要求。在面试时,我们一般会让选择了上述方法的候选人把他们的想法说完,这样至少让他们在心理上不至于感受到打击,但是接下来我们会要求他们找出不使用额外内存空间的方法。

很多人想到的是把上面句子中的单词前后对调。但这道题目的难点恰恰在于英语单词的长度不同,如果不使用额外的空间,很难把不同长度的单词对调。

学习计算机的人会想到记录下来句子一头一尾两个单词的长度,然后把长的那个单词先挪开&#x

文章来源: howard2005.blog.csdn.net,作者:howard2005,版权归原作者所有,如需转载,请联系作者。

原文链接:howard2005.blog.csdn.net/article/details/106410933

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。