PAT-乙级-1009 说反话(C语言)

1009 说反话(C语言)

题目描述

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子。

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

解题思路

第一步

先定义一个长度为81的字符数组array[81]来存储字符串,因字符串中带空格,
而scanf()函数遇到空格会停止输入,所以用gets()函数代替scanf()进行输入。

第二部

使用while()函数结束条件为找到'\0'结束符循环遍历字符数组,确定字符串长度i。

第三步

反向遍历字符串数组匹配空格,输出空格后的单词,再将空格符为结束符'\0',
当遍历到倒数第二个空格时,输出倒数第二个空格后面的单词时,当输出到原倒数第一个空格的位置时,
其存储内容为'\0'结束符,故而输出结束。

以此类推,可以从后往前输出n-1个单词,因首单词前面没有空格。

第四步

直接输出字符串array

因为首单词后的空格已经置为结束符’\0’,所以将首单词输出后会直接结束。

程序结束

具体代码

内存200KB,用时3ms

#include <stdio.h> 

int main(){
	int i=0;
	char array[81];
	gets(array);						//scanf无法直接输入带空格的字符串,所以用gets函数
	while(array[i]!='\0') i++;			//while循环遍历出字符串长度
	for(;i>=0;i--){						
		if(array[i]==' '){				//从后往前匹配空格
			printf("%s ",&array[i+1]);	//输出空格后的字符串
			array[i]='\0';				//将空格置为结束符
		}	
	}
	printf("%s",array);					//输出字符串的第一个单词
    return 0;
}

提交结果:

1009 说反话

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沈临空

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值