6-34 删除字符 (20 分)
本题要求实现一个删除字符串中的指定字符的简单函数。
函数接口定义:
void delchar( char *str, char c );
其中char *str是传入的字符串,c是待删除的字符。函数delchar的功能是将字符串str中出现的所有c字符删除。
裁判测试程序样例:
#include <stdio.h>
#define MAXN 20
void delchar( char str, char c );
void ReadString( char s[] ); / 由裁判实现,略去不表 */
int main()
{
char str[MAXN], c;
scanf("%c\n", &c);
ReadString(str);
delchar(str, c);
printf("%s\n", str);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
a
happy new year
输出样例:
hppy new yer
void delchar( char *str, char c ){
int q,flagi,i;
while(1)
{ q=0;//循环检测的标志
for(i=0;*(str+i)!=NULL;i++)//是否有字符需要删除
{
if(*(str+i)==c){
flagi=i;q=1;break;}//记录下标,本次不退出外循环
}
if(!q)
break;//不需要删除退出外循环
else
{
for(i=flagi+1;*(str+i)!=NULL;i++)//标记位置+1从左到右遍历,后面的字符给前面(往前移一格)
{
*(str+i-1)=*(str+i);
}
*(str+i-1)=NULL;//最后一个是NULL,直接退出了,在删除后最后面用一个NULL代替之前的最后一个非NULL字符
}
}
}