每日一题(02):倒置字符串

学习启示:

1.首先这是一道操作题。初态和末态已知。所以要考虑 “模板的映射”。

2.基本功:熟练的双层循环操作+写初末终止条件

3.熟能生巧:auto关键字的应用,不断地自动赋值+(C++STL库的应用)

4.模板映射---》数据可以分为字母,数字,空格.....等。可以改变数据范围(限定字母用ACII来判断)倒置格式的不同设定。

5.”思路问题“---》有点递归的思想。如果没有分析出倒两次等于自己的事实(a与b异或两次等于b,,,有的时候思路是抽象的,也依赖于当时的灵感),就不会想到将单词封装成一个再倒置,就可能会通过逐个遍历字母的方式取取反,会很混乱。边界判断越多,越用容易写错。循环一次,就代表可能带来O(n)复杂度,所以要灵活考虑简化。

6.STL库本质上是数据结构,处理字符串和链表等问题,借鉴思想和分析方式,配合循环和写判断条件的基本功。另一边还要借助STL库的遍历,简化步骤。

即使边界多,一步步写,也不易出错

伪代码
1.输入输出格式,以头文件,完成变量初始化
2.整体逆置
3.单词逆置
检索每个单词,一个单词逆置一次,
每个单词逆置条件: 右边界(s.end)遇到空格
4.处理边界,字符串以/0结尾。标志着检索和逆置结束
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
	string s;
	getline(cin, s);
	//翻转整个句子
	reverse(s.begin(), s.end());
	//翻转单词
	auto start = s.begin();
	while (start != s.end())
	{
		auto end = start;
		while (start != s.end() && *end != ' ')
			end++;
		reverse(start, end);
		if (end != s.end())
			start = end + 1;
		else
			start = end;
	}
	cout<< s << endl;
	return 0;
}

受限于知识,只是对当下的基础学习做一下总结,思路和知识上面尚且不足,如有错误欢迎指正!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

刘敬_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值