题目:
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
分析:
- 用getchar()函数从标准输入中给数组str赋值,注意每次一个字符赋值后,都要在后面添加 ‘\0’ 。
- 要实现说反话,可以先令一个指针指向该字符串的末尾,而后让该指针向前移动,每遇到空格就停止移动,而后输出该单词。
程序:
#include <stdio.h>
void PrintReverseTalking(char *str);
int main(){
char str[81];
char c;
int i = 0;
str[0] = '\0';
while((c = getchar()) != '\n' && i < 81){
str[i] = c;
str[++i] = '\0';
}
PrintReverseTalking(str);
return 0;
}
void PrintReverseTalking(char *str)
{
char *p;
int i;
p = str;
while(*(++p) != '\0') ; //指向字符串末尾
for(; p != str ; p--){ //输出除第一个单词外的所有单词以及空格
if(*p == ' '){
for(i = 1; *(p + i) != ' ' && *(p + i) != '\0'; ++i ){
printf("%c", *(p + i));
}
printf(" ");
}
}
// 输出第一个单词,末尾无空格
for(i = 0; *(p + i) != ' ' && *(p + i) != '\0'; ++i){
printf("%c", *(p + i));
}
}