给一个字符串,反转其中的单词。单词为连续的字符串序列
"abc, defg|ghi xyz"
“cba, gfed|ihg zyx”
其中的细节,数组遍历的边界,调试了好几遍才写出来
// ConsoleApplication1.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <string>
#include <iostream>
using namespace std;
string trans(string s);
string revers(string &s, int start, int len);
int _tmain(int argc, _TCHAR* argv[])
{
string t = "abcdefg";
cout << endl << revers(t, 0, 5);
string s = "abc, defg|ghi xyz";
cout << trans(s);
getchar();
return 0;
}
// 反转字符串中的特定一段
string revers(string &s, int start, int len)
{
int end = start + len - 1;
for (int i = 0; i != len / 2; ++i)
{
char temp = s[end - i];
s[end - i] = s[start + i];
s[start + i] = temp;
}
return s;
}
// 遍历字符串将其中的单词反转
string trans(string s)
{
int start = 0;
int length = 0;
for (auto c : s)
{
if ('a' <= c && c <= 'z')
{
length++;
}
else
{
if (length != 0)
{
cout << length <<" " << start << endl;
revers(s, start, length);
start = start + length;
length = 0;
}
if (length == 0)
start++;
}
}
// 如果字符串的最后一位还是字母时,长度不为0,还需要检测一遍
if (length != 0)
{
cout << length << " " << start << endl;
revers(s, start, length);
start = start + length;
length = 0;
}
return s;
}