标题:删除字符串中的*字符连续字符保留,比如***A*B*C***调用函数完以后***ABC** ...
只看楼主
iqyuankong
Rank: 2
等 级:论坛游民
帖 子:68
专家分:10
注 册:2009-10-23
结帖率:92.86%
已结贴  问题点数:10 回复次数:3 
删除字符串中的*字符连续字符保留,比如***A*B*C***调用函数完以后***ABC***
#include <stdio.h>
void  fun( char *a )            /*请帮忙补充函数并解释下这个算法的思想,本人愚钝想了好久没有明白!*/
{


}

main()
{  char  s[81];
   void NONO (  );
   printf("Enter a string:\n");gets(s);
   fun( s );
   printf("The string after deleted:\n");puts(s);
   NONO();
}
void NONO()
{/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */
  FILE *in, *out ;
  int i ; char s[81] ;
  in = fopen("in.dat","r") ;
  out = fopen("out.dat","w") ;
  for(i = 0 ; i < 10 ; i++) {
    fscanf(in, "%s", s) ;
    fun(s) ;
    fprintf(out, "%s\n", s) ;   
  }
  fclose(in) ;
  fclose(out) ;
搜索更多相关主题的帖子: 函数 ABC 删除 字符 
2010-03-24 20:42
ldg628
Rank: 12Rank: 12Rank: 12
等 级:火箭侠
威 望:3
帖 子:526
专家分:3036
注 册:2009-6-23
得分:3 
void fun(char *a)
{
    int i = 0, j = 0, flag = 0, len = 0;
    while (a[i])
    {
        if (a[i] == '*')   
        {
            if (flag == 0)//如果flag == 0,说明是开头的'*',不变
            {
                j ++;
            }else //如果flag !=0 ,说明不是开头的'*"了,j不再自加,并先给a[j+len]赋值,再len计数;如果不是到结尾的'*',会再遇到不是'*'的字符,就要从位置j开始赋值,删掉中间的"*",如果是结尾的'*',可以通过j ,len找到字符串的结尾
            {
                a[j+len++] = a[i];
            }
        }else //遇到不是‘*’的字符,使flag=1,以后再遇到的'*'就不是开头的了
        {
            flag = 1;
            a[j++] = a[i]; //给不是'*'的地方赋值
            len = 0;//重新计算下一段的'*'号个数
        }
        i ++;
    }
    a[j+len] = 0; //给字串的尾部置'\0'
}
2010-03-24 22:42
一口三个汉堡
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:3
帖 子:155
专家分:525
注 册:2010-3-21
得分:3 
void  fun(char *a)           
{
    int start=0,end=0,i,j;
    for(i=0;a[i]!='\0';i++)//计算它最后一个非*字符的位置
        if(a[i]!='*'&&a[i]!='\0')
            end=i;
    for(i=end;i>=0;i--)//计算它第一个非字符的位置
        if(a[i]!='*')
            start=i;
    for(i=start,j=start;a[i]!='\0';i++)从第一个非*位置开始删除*到最后一个非*结束删除
        if(a[i]!='*'||i>end)
            a[j++]=a[i];
    a[j]='\0';
}
我的想法是这样,但为什么会出现

谁能告诉我啊

坚持做对的事情,而不是容易的事情。
2010-03-24 23:30
小访客
Rank: 2
等 级:论坛游民
帖 子:24
专家分:18
注 册:2009-11-10
得分:3 
int i,j=0;
for(i=0;a[i]!='\0';i++)
{
    if((a[i]==*)&&(aa[i]!=a[i+1]))//判断数组中是否有*并且不连续
     {
         a[j++]=a[i];              //将不是星号且不连续的元素赋给 a[]形成新数组
     }
     a[j]='\0';
}
我这没有软件 你验证一下应该可以
2010-03-31 08:46



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-300440-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.130812 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved