一、算法描述
逐个比较字符串source中的字符,若当笑悉前i位置的字符等于待删除字符ch,则i+1..len-1之间租祥的子串整体前移弊升搏;如此反复,直到所有待删除字符都找到并被删除为止。
二、操作过程
三、参考程序
#include
#include
/* 移除字符串source中的所有ch字符 */
void remove(char *source, char ch);
void main()
{
char source[1000];
char ch;
printf("请输入一个字符串:");
gets(source);
printf("请输入待删除字符:");
ch = getchar();
remove(source, ch);
printf("新的字符串:");
puts(source);
}
/* 移除字符串source中的所有ch字符 */
void remove(char *source, char ch)
{
int i, j;
int len = strlen(source);
for(i=0; source[i]!='\0'; i++)
{
if(source[i] == ch)
{
for(j=i+1; source[j]!='\0'; j++)
{
source[j-1] = source[j];
}
source[j-1] = '\0';
}
}
}
四、运行测试
请输入一个字符串:How are you?
请输入待删除字符:o
新的字符串:Hw are yu?
挑出凳扮察其中缺烂需要的字符枣茄存回来就行了
#include "stdio.h"
#include "string.h"
#include "stdlib.h"
void delChar(char *str,char m)
{
int len=strlen(str);
int i,j=0;
char *p=(char *)malloc(len*sizeof(char));
memset(p,0,len);
for(i=0;i { if(*(str+i)!=m) *(p+j++)=*(str+i); } memset(str,0,len); strncpy(str,p,strlen(p)); free(p); } int main() { char str[100]={0}; char del; scanf("%s %c",str,&del); delChar(str,del); puts(str); } 结果:
char chr[5] = "abccd";
char chr1[1] = "c";
int j=0;
for(int i =0;i<5;i++)
{
if(chr[i]=="c")
j++;/桐乱茄/先算出有几个符合的
}
char chrNew[j];
int m=0;
for(int k =0 ; k<5;k++)
{
if(chr[k]!="c")
chrNew[m] = chr[k];
m++;
}
此时获陪老得的chrNew就是新的删除之后的字符串了
基本类型中不支持删局察除操作,所以实际上就是一个新的字符串。
#include
#include
main()
{char a[80];
int i,j,pos,y;
char ch;
while(true)
{
printf("请输搏枣入一行字符串:\n");
gets(a);
printf("请输入要删去的字符:\n",ch);
scanf("基轿拆帆漏%c",&ch);
for(i=0;i
{ pos=i;
a[pos]=' ';
}
for(j=pos;j
a[strlen(a)-1]='\0';
printf("%s\n",a);
printf("退出输入0,继续输入1:\n");
scanf("%d",&y);
if(y==1)
scanf("%c",&ch);
if(y==0)
break;
}
这个比较简单,先strchr查找下,然后memmov就可以了