倒置字符串(两种解法)

题目描述

将一句话的单词进行倒置,标点不倒置。比如 I like beijing. 经过函数后变为:beijing. like I

第一种解法

#include <iostream>
#include <string> 
#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 (end != s.end() && *end != ' ')
			end++;
		reverse(start, end);

		if (end != s.end())
			start = end + 1;
		else
			start = end;
	}

	cout << s << endl;

	return 0;
}

第二种解法

#include <iostream> 
#include <string> 
using namespace std;
// cin读取string时自动会被空格分隔开,用另一个字符串存储进行逆序输出 
int main() 
{  
	string s1, s2;  
	cin >> s2;   
	while (cin >> s1)  
		s2 = s1  + " " + s2;  
	cout << s2 << endl;   
	return 0; 
}
全部评论

相关推荐

一个菜鸡罢了:哥们,感觉你的简历还是有点问题的,我提几点建议,看看能不能提供一点帮助 1. ”新余学院“别加粗,课程不清楚是否有必要写,感觉版面不如拿来写一下做过的事情,教育经历是你的弱势就尽量少写 2. “干部及社团经历”和“自我评价”删掉 3. 论文后面的“录用”和“小修”啥的都删掉,默认全录用,问了再说,反正小修毕业前肯定能发出来 4. 工作经验和研究成果没有体现你的个人贡献,着重包装一下个人贡献
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务