/*
分析:其实就是要看遇到一个空格,接下来的是不是空格直到结尾,从这个空格开始删除,
那么怎么判断完后面假如是直到末尾的话返回到这个空格的位置呢,我觉得可以定义一个
字符串,然后当你遇到这个空格就调用函数来判断后面是否是我们想要的结果,然后
根据情况返回下标。
*/
#include<stdio.h>
#include<string.h>
#define LEN 20
int FAN(char *s,int n);
int main()
{
char s[LEN]; //先定义一个字符串
int i,n,len;
gets(s); //输入字符串
while(*s!=NULL) //当字符串不为空时继续
{
len=strlen(s); //计算字符串长度
for(i=0;i<len;i++) //循环比较
{
if(s[i]==' '||s[i]=='\t') //当遇到空格或者制表符进行判断
{
if(s[++i]=='\0') //若是他的下一个就是字符串结束符,表示末尾就一个空格或者制表符
{
s[--i]='\0'; //因为前面对i加一了,所以要减一回到原来遇到空格那个i处把他变成字符串结束符号就可以
break; //因为已经知道他就是最后一个空格 ,不需要比较下一个,直接退出循环就可以了
}
else //到这里表示该空格或者制表符并不是最后一个,所以继续看他后面是否还有空格或者制表符直到末尾
{
i--; //注意前面比较时时若是不符合的话,i已经加一并且没有减一,所以这里我们需要减一
n=FAN(s,i); //调用函数判断是否符合条件
if((n<0)) //这里表示符合条件就把它变成结束符号跳出循环
{
s[i]='\0';
break;
}
else //否则的话不符合,就从不符合的那个字符那里继续向后比较
i=n;
}
}
}
i=0; //输出字符串,这里我没有用puts,因为它自动换行,但是我后面还想输入一个1测试,所以这样输出的
while(s[i]!='\0')
{
printf("%c",s[i]);
i++;
}
printf("l"); //用来测试是否删除成功,成功的话1是紧挨着每一行字符串最后一个字符末尾
putchar('\n');
gets(s);
}
return 0;
}
int FAN(char *s,int n) //用来判断后面是不是我们想要的结果
{
int i=n;
int len=strlen(s); //字符串长度
for(i;i<len;i++)
{
if(s[i]==' '||s[i]=='\t') //假如后面还是空格或者制表符继续往后查看直到字符串末尾
n++;
else //若是有一个不一样的返回0
return i;
}
return -1; //表示是我们想要的结果返回1
}
编写一个程序删除每个输入行末尾的空格以及制表符,并且删除完全是空格的行
最新推荐文章于 2023-07-13 20:00:16 发布