PTA 7-32 说反话-加强版 (C/C++)

这篇博客介绍了一种优化方法来解决PTA中的一个问题——反转英语句子中单词的顺序。作者指出,避免复制单词并直接在原始字符串上进行操作可以提高效率。通过替换空格为字符串结束符,可以确定每个单词的边界,然后逆序输出这些边界即可。这种方法适合处理长字符串,避免了额外的空间消耗。

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

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过500 000的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用若干个空格分开。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子,并且保证单词间只有1个空格。

输入样例:

Hello World   Here I Come

结尾无空行

输出样例:

Come I Here World Hello

结尾无空行

分析:做题之间先想思路,这道题通常的做法是建立一个二维字符数组 / (vector <string>数组 ),然后依次遍历原字符数组,碰到空格跳过,将单词复制到新建的数组中。细想一下,这么做太麻烦了,复制过程既耗时又占用空间,况且本题字符串长度很长,不妨想个新方法,使得尽量在原数组上改动,而不复制。

可以试试这么干:依次遍历原字符数组,将空格替换成字符串结束符,那么每个单词的终止位置就知道了,所以只需要记录单词的起始位置就行了。(这个方法对于没学C++的同学也好理解的。)最后逆序输出,代码如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值