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

吴军博士分享了一个谷歌面试题,要求不使用额外存储空间将英文句子完全倒置。常见方法是通过单词对调,但因单词长度不同导致困难。正确解法是先将句子视为字母串整体头尾对调,再逐单词内部对调,以此得到倒置句子。这种方法打破了常规思维定势,很多面试者未能找到此解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

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

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

学习计算机的人会想到记录下来句子一头一尾两个单词的长度,然后把长的那个单词先挪开,短的那个填进长的单词空出来的位置。

比如在上面的例子中,London这个词比较长,down这个词比较短,可以把London先挪出来,把down这个词放到London的位置中,这是放得下的。但是这样接下来的问题又来了,长的单词L

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酒城译痴无心剑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值