1009 说反话 (20 分)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
这道题把每一个空格看做一个分隔区域
1.输入一个字符数组
2.从后遍历字符数组,因为数组是从0开始,如果字符串长度为5,那么它的最大下标就是arr[4],从后向前遍历,就要减1再开始遍历
3.当然遍历的话,有无空格就是判断是否为一个单词的条件
4.遇到空格怎么办?当然是从空格处开始输出,空格处是位置 i ,str+i就是到了空格的位置,str+i+1才是空格后面的内容
5.每次输出一个单词就把刚刚的空格变为'\0',表示字符数组结束,如果不加的话,到倒数第二个空格是输出,就会输出 I Come,加上'\0',就输出 I
6.因为第一个字母前面没有空格,所以要单独处理,for循环在循环到Hello后面的空格时,正好把空格变为'\0',所以我们直接输出str就可以,这是的str就只剩Hello因为在循环里面,已经把空格变为了'\0',这个结束标志
代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
/*
s = "abcdefg"
输出s 就是 abcdefg
就像从b开始输出就s+1从b开始输出bcdefg
*/
int main()
{
char str[100];
gets(str);
int i;
for(i=strlen(str) - 1 ; i >= 0 ; i--) //从后遍历数组
{
if(str[i] == ' ')//如果遇到空格就输出
{
//输出空格后面的str+i到空格位置,str+i+1 就是输出空格后面,就写数组名表示的是数组首地址
printf("%s ",str+i+1);
//把遇到的空格变为0表示字符串结束
str[i] = '\0';
}
}
//上面是找空格作为条件,但是第一个单词前面没有空格,所以就单独输出
printf("%s",str);
return 0;
}