码迷,mamicode.com
首页 > 其他好文 > 详细

42.翻转单词顺序VS左旋转字符串

时间:2015-07-11 09:17:52      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:数组

技术分享

技术分享

技术分享

技术分享

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;
}

技术分享




版权声明:本文为博主原创文章,未经博主允许不得转载。

42.翻转单词顺序VS左旋转字符串

标签:数组

原文地址:http://blog.csdn.net/wangfengfan1/article/details/46835233

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!