欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

2. 反转单词的两种解决方案

程序员文章站 2022-05-31 08:04:33
...

编写一个函数,反转一个字符串中单词的顺序。例如,函数应该将字符串Life is better and better.转换成better. and better is Life。假定所有的单词都是以空格分隔的,标点也作为字母一样处理。 1. 通用的解决方法 通用解决方案的工作原理如下: 首先,需要

编写一个函数,反转一个字符串中单词的顺序。例如,函数应该将字符串“Life is better and better.”转换成“better. and better is Life”。假定所有的单词都是以空格分隔的,标点也作为字母一样处理。

1. 通用的解决方法

通用解决方案的工作原理如下:

首先,需要分配适当大小的临时缓冲区。然后,需要进行扫描循环,从字符串的最后一个字符开始。当发现非单词字符时,可以将它直接写到缓冲区中去。但是,当发现单词字符时,不能立即将它写入临时缓冲区。因为是在反向扫描这个字符串,遇到的第一个字符,正好是这个单词的最后一个字符,所以如果按发现字符的顺序复制,会使每个单词中的字符发生反转。所以,需要继续扫描,直到找到这个单词的第一个字符,再将这个单词的每个字符以正确的、不反转的顺序进行复制。当复制一个单词的字符时,需要确定这个单词的结尾,这样才能知道何时停止复制。可以通过检查每个字符是否是单词字符来实现这一点,但因为已经知道了这个单词最后一个字符的位置,更好的方法是进行复制直至到达这个位置。

程序代码如下:

#include "stdafx.h"
#include
#include

#include

bool reverseWords(char str[])
{
char *buffer;
int tokenReadPos, wordReadPos, wordEnd, writePos = 0;

// Position of the last character is length - 1
tokenReadPos = strlen(str) - 1;

buffer = (char*)malloc(tokenReadPos + 2);


if(!buffer)
return false; // reverseWords failed

while(tokenReadPos >= 0)
{
if(str[tokenReadPos] == ' ') // Non-word characters
{
// Write character
buffer[writePos++] = str[tokenReadPos--];
}
else // Word character
{
// Store position of end of word
wordEnd = tokenReadPos;

// Scan to next non-word character
while(tokenReadPos >= 0 && str[tokenReadPos] != ' ')
tokenReadPos--;

// tokenReadPos went past the start of the word
wordReadPos = tokenReadPos + 1;

// Copy the characters of the word
while(wordReadPos {
buffer[writePos++] = str[wordReadPos++];
}
}
}

// null terminate buffer and copy over str
buffer[writePos] = '/0';


strcpy(str, buffer);

free(buffer);

return true; // ReverseWords successful
}

int main()
{
char str[] = "Life is better and better!";

cout reverseWords(str);
cout

return 0;
}

程序的运行结果如下图所示:

2. 反转单词的两种解决方案

2. 专用的解决方法:

专用解决方法的原理如下:

首先,将整个字符串进行反转。然后,对反转后的每个单词进行反转。与通用解决方法相比,专用解决方法的好处是不需要缓冲区。

程序代码如下:

#include "stdafx.h"
#include
#include

void reverseString(char str[], int start, int end)
{
char temp;
while(end > start)
{
// Exchange characters
temp = str[start];
str[start] = str[end];
str[end] = temp;

// Move indices towards middle
start++; end--;
}
}

void reverseWords(char str[])
{
int start = 0, end = 0, length;

length = strlen(str);

// Reverse entire string
reverseString(str, start, length - 1);

while(end {
if(str[end] != ' ') // Skip non-word characters
{
// Save positions of beginning of word
start = end;

// Scan to next non-word character
while(end end++;

// Back up to end of word
end--;

// Reverse word
reverseString(str, start, end);
}
end++; // Advance to next token
}

}

int main()
{
char str[] = "Life is better and better!";

cout reverseWords(str);
cout

return 0;
}

程序的执行结果如下:

2. 反转单词的两种解决方案