void Reserve(char* pBegin, char* pEnd)
{
if (pBegin == NULL || pEnd == NULL || pBegin+1==pEnd)
return;
while (pBegin < pEnd)
{
std::swap(*pBegin,*pEnd);
pBegin++;
pEnd--;
}
}
void ReserveSentense(char* pData)
{
if (pData == NULL)
return;
char* pBegin = pData;
char* pEnd = pBegin;
while (*pEnd != '\0')
pEnd++;
pEnd--;
Reserve(pBegin, pEnd);
pEnd = pBegin = pData;
while (*pBegin != '\0')
{
if (*pBegin == ' ')
{
pBegin++;
pEnd++;
}
else if (*pEnd == ' ' || *pEnd == '\0')
{
Reserve(pBegin, --pEnd);
pBegin = ++pEnd;
}
else
++pEnd;
}
}
void LeftRotateStr(char*pStr, int n)
{
if (pStr == NULL || n<= 0)
return;
int len = strlen(pStr);
n %= len;
char* pFirstStart = pStr;
char* pFirstEnd = pStr + n - 1;
char* pSecondStart = pStr + n;
char* pSecondEnd = pStr + len - 1;
Reserve(pFirstStart, pFirstEnd);
Reserve(pSecondStart, pSecondEnd);
Reserve(pFirstStart, pSecondEnd);
}