翻转小段单词
其实翻转字符串能够通过多次的字符串的逆序实现,这里主要学习一下,怎么提取每一个英语单词,然后分别对其逆序。
string ReverseSentence(string str)
{
int size = str.size();
char *pFirst = &str[0];
char *pEnd = &str[size - 1];
Reverse(pFirst, pEnd);
pFirst = &str[0];
pEnd = pFirst;
while(*pFirst != '\0')
{
if(*pFirst == ' ')
{
++pFirst;
++pEnd;
}
else if(*pEnd == ' ' || *pEnd == '\0')
{
Reverse(pFirst, --pEnd);
pFirst = ++pEnd;
}
else
{
++pEnd;
}
}//for
return str;
}
void Reverse(char *pBegin, char *pEnd)
{
if(pBegin == NULL || pEnd == NULL)
{
return;
}
while(pBegin < pEnd)
{
char tmp = *pBegin;
*pBegin = *pEnd;
*pEnd = tmp;
pBegin++;
pEnd--;
}//while
}
查找和为S的连续数组元素
void findContinuousSequence(int sum)
{
int small = 1;
int big = 2;
int mid = ( 1+ sum) / 2;
int curSum = small + big;
while(small < mid)
{
if(curSum < sum)
{
++big;
curSum += big;
}
else if(curSum > sum)
{
curSum -= small;
++small;
}
else
{
int j = 0;
for(j = small; j <= big; j++)
{
printf("%d ", j);
}
printf("\n");
++big;
curSum += big;
}//else
}//while
}
这两个问题的共同点就是处理一个问题的连续的一小段问题,解决的办法和划分中使用的一样,利用快慢指针。