单词逆序
题目:
对于一个字符串,请设计一个算法,只在字符串的单词间做逆序调整,也就是说,字符串由一些由空格分隔的部分组成,你需要将这些部分逆序。 给定一个原字符串A,请返回逆序后的字符串。
- 时间要求:1s
- 空间限制:65536K
输入描述:
输入一行字符串str。(1<=strlen(str)<=10000)
输出描述:
返回逆序后的字符串。
示例1
输入
It's a dog!输出
dog! a It's
我的作答 编译器:C++11(clang++3.9)
#include <stdio.h>
#include <string.h>
int main()
{
char str[10000];
memset(str, 0, 10000);
gets(str);
char temp[10000];
int i, k;
int j = 0;
for(i = strlen(str) - 1; i >= 0; --i)
{
if(str[i] == ' ')
{
for(k = strlen(temp) - 1; k >= 0; --k)
{
printf("%c", temp[k]);
}
printf(" ");
memset(temp, 0, 10000);
j = 0;
}
else
{
temp[j] = str[i];
++j;
}
}
if(i < 0)
for(k = strlen(temp) - 1; k >= 0; --k)
{
printf("%c", temp[k]);
}
return 0;
}