免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123
最近访问板块 发新帖
楼主: pczxllwxd
打印 上一主题 下一主题

请教一个字符串插入另一字符串指定位置得问题! [复制链接]

论坛徽章:
0
21 [报告]
发表于 2006-08-30 16:29 |只看该作者

给楼主的,

#include<stdio.h>
#include<stdlib.h>

void fun(char * deststr,char * sourstr,int pos);

int main(){
        int i=0;
        char str1[]="this is a destination string!";
        char str2[]="******";
        fun(str1,str2,4);
        printf("After calling fun,the str1 is \n");
        printf("%s\n",str1);
        return 0;
}
void fun(char * deststr,char * sourstr,int pos){
                 int length1;
                 int length2;
                 int flag;
                 char * string1;
                 char * string2;
                 char * p;
                 string1=deststr;
                 length1=0;
                 length2=0;
                 while(*string1++!='\0'){
                         length1++;
                 }
                 
                 string2=sourstr;
                 while(*string2++!='\0'){
                         length2++;
                 }
                 printf("len1=%d,len2=%d\n",length1,length2);
                 
                 if(pos>length1){
                         printf("out of the string range!\n");
                         return ;
                 }
     
         p=(char * )malloc(length1-pos);

                 string1=deststr;
                 string2=sourstr;
         string1=string1+pos;
                 flag=0;
                 do{
                         p[flag++]=*string1++;
                 }while(*string1!='\0');
                 p[flag]='\0';
         
             string1=deststr+pos;
             for(flag=0;flag<length2;flag++)
                         *string1++=string2[flag];
         
                 flag=0;
                 while(p[flag]!='\0')
                         *string1++=p[flag++];
                 free(p);
}

调试通过了。。

本人认为对于字符串的改变,只能是这个思路了,如果不用库函数的话,呵呵。

论坛徽章:
0
22 [报告]
发表于 2006-08-30 17:01 |只看该作者
{
      char * p1 = s1;
      char * p2 = s2;
      /*判断s1够不够长*/
      int i;
      for( i = 0; i< pos; i++)
      {
            p1++;
            if( *p1 == '\0' )
                 break;
      }
      if( i == pos )
             p1= s1+pos;
      else
             return -1; //或者 p1 = s1+i;
      char tmp;
      i = -1;
      while( *p1 != '\0' )
      {
            int lens2 = 0;
           while( *p2 != '\0' )
          {
                tmp = *p1;
                *p1 = *p2;
                *p2 = tmp;
                lens2++;p1++;p2++;
          }
            if( i >= 0 && i != lens2 )
            {
                  *p1 = '\0';
                  break;
            }
            else
            {
                  p2 = s2;
                  i = lens2;
            }
      }
}

也许可以吧,临时写的,有点乱
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP