42.翻转单词顺序VS左旋转字符串
2015-07-10 21:28
393 查看
void Reverse(char* pBegin, char* pEnd)
{
if (pBegin == NULL || pEnd == NULL)
return;
while (pBegin < pEnd)
{
char temp = *pBegin;
*pBegin = *pEnd;
*pEnd = temp;
pBegin++, pEnd--;
}
}
char* ReverseSentence(char *pData)
{
if (pData == NULL)
return NULL;
char* pBegin = pData;
char* pEnd = pData;
while (*pEnd != '\0')
pEnd++;
pEnd--;
//翻转整个句子
Reverse(pBegin, pEnd);
//翻转句子中的每个单词
pBegin = pEnd = pData;
while (*pBegin != '\0')
{
if (*pBegin == ' ')
{
pBegin++;
pEnd++;
}
else if (*pEnd == ' ' || *pEnd == '\0')
{
Reverse(pBegin, --pEnd);
}
else
{
pEnd++;
}
}
return pData;
}
char* LeftRotateString(char* pStr, int n)
{
if (pStr != NULL)
{
int nLength = static_cast<int>(strlen(pStr));
if (nLength > 0 && n > 0 && n < nLength)
{
char* pFirstStart = pStr;
char* pFirstEnd = pStr + n - 1;
char* pSecondStart= pStr + n;
char* pSecondEnd = pStr + nLength - 1;
//翻转字符串的前面n个字符
Reverse(pFirstStart, pFirstEnd);
//翻转字符串的后面部分
Reverse(pSecondStart, pSecondEnd);
//翻转整个字符串
Reverse(pFirstStart, pSecondEnd);
}
}
return pStr;
}
相关文章推荐
- 给儿子讲美国独立战争
- 设计模式读书笔记:State(状态)
- IOS--UI--LessonNavigationController
- Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java
- Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java
- Android_Touch事件的分发和消费机制
- 任正非转型狠招:如何让宝马追上特斯拉?
- atitit.微信支付的教程文档 attilax总结
- Swift之使用UIAlertController实现UIActionsheet
- 41.和为s的两个数字VS和为s的连续正数序列
- HDoj-2524 - 矩形A+B
- C++运算符重载(成员函数方式)
- atitit.微信支付的教程文档 attilax总结
- 第2章 字符和字符串处理(1)
- Subsets
- 如何在discuz帖子中插入视频
- 欢迎使用CSDN-markdown编辑器
- mybatis 添加事物后 无法获取自增主键的问题
- VMware虚拟机下 Redhat上网
- atitit.http get post的原理以及框架实现java php