/*
这题是一个简单的模拟题。但是这题很容易PE,要仔细读题。
题目中说了要把连续的空格压缩成一个
如果在字符串前面或者后面有空格的时候也是要处理的
比如下面的数据
9
__ab__d__
下划线代表空格
还有一个要注意的就是用gets()读入的时候要先gets()一下把前面数字后面的回车读入。
*/
#include <stdio.h>
#include <string.h>
#include<algorithm>
using namespace std;
char str[100000+10];
int main()
{
int n;
int j,x;
while(scanf("%d",&n)!=EOF)
{
gets(str);
gets(str);
//len = strlen(str);
for(int i=0;i<n;i++)
{
if(str[i]!=' ' && (i==0 || str[i-1]==' '))
{
for(j=i;j<n && str[j]!=' ';j++);
reverse(str+i,str+j);
for(x=i;x<j;x++)
putchar(str[x]);
i=j-1;
}
else if(str[i]==' ' && (i==0 || str[i-1]!=' '))
putchar(' ');
}
printf("\n");
}
return 0;
}
题目1525:子串逆序打印
最新推荐文章于 2021-07-18 19:08:53 发布