定义一个函数delete_char(),其中包含两个形参:一个是字符型,一个是字符串型。该函数返回一个整数。函数的功能是在字符串中删除所有的字符型数据,并删除的个数作为函数的返回值。编写主函数调用该函数。要求在主函数中动态分配一组空间,将字符串输入该动态空间。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(){
int delete_char(char *b,char *q);
char a,*p;
int num;
p=(char *)malloc(100*sizeof(char));
scanf("%c",&a);
getchar();
gets(p);
num=delete_char(&a,p);
printf("%d",num);
puts(p);
return 0;
}
int delete_char(char *b,char *q){
int i,num=0,j;
int len=strlen(q);
for(i=len-1;i>=0;i--){
if(*(q+i)==*b){
for(j=i;*(q+j)!='\0';j++){
*(q+j)=*(q+j+1);
}
num++;
}
}
return num;
}
其实这道题的逻辑并不难,但是很容易有一个误区,这是小编在写的时候遇到的:大家删除字符很容易想到的是正向删除,也就是从前往后一次删除,但是这样很难保证,你可以删除完所有的字符。例如:qaaaa,当你想要删除字符a时,你会发现结果却是qaa,因为你正向删除时,你删除完一个你就会直接遍历下一个。
其实想要避免上述错误,我们可以逆向思考,改变方向,从后向前遍历,逆向思维在编程中很重要,可以帮助我们解决一些逻辑复杂的问题,特别是在字符串的删除中可以用到。这也是我在考研时颉斌斌老师技巧课时交给我的一个重要的思维。哈哈
C语言小白编写
感谢各位大佬批评指正!
祝你们生活愉快~