注册 登录
编程论坛 数据结构与算法

请大家看看 我这个函数的串连接功能为什么不能实现!

lufeng1720 发布于 2010-05-19 11:52, 583 次点击
#include<stdio.h>
#include<stdlib.h>
#include <string.h>
#define MAXLEN 100
typedef struct
{char vec[MAXLEN];
    int len;
}str;
int i,j,k;
int lenstr(str *r)
{int i=0;
while(r->vec[i]!='\0')
    i++;
    return i;
}
char concatstr(str *r1,str *r2)
{if(r1->len+r2->len>MAXLEN)
    printf("两个串太长,溢出!");
    else
    {for(i=0;i<r2->len;i++)
        r1->vec[r1->len+i]=r2->vec[i];
        r1->vec[r1->len+i]='\0';
        r1->len=r1->len+r2->len;
    }
    return r1->vec;
}
    void main()
    {int i;
    int j;
    int k;
    str *r;
    str *r1;
    str *r2;
    r=malloc(sizeof(str));
    r1=malloc(sizeof(str));
    r2=malloc(sizeof(str));
    r->len=0;
    r1->len=0;
    r2->len=0;
    gets(r->vec);
    gets(r1->vec);
    printf("第一个长为%d\n",lenstr(r));
    printf("第二个长为%d\n",lenstr(r1));
    concatstr(r,r1);
    printf("连接后的串为");
    puts(r->vec);
   
    }
   
   
1 回复
#2
寒风中的细雨2010-05-30 11:36
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAXLEN 100

typedef struct
{
    char vec[MAXLEN];
    int len;
}str;

int i,j,k;
int lenstr(str *r)
{
    int i=0;
    while(r->vec[i]!='\0')
        i++;
    return i;
}

void concatstr(str *r1,str *r2)
{
    if(r1->len+r2->len>MAXLEN)
        printf("两个串太长,溢出!");
    else
    {
        for(i=0;i<r2->len;++i)
            r1->vec[r1->len+i]=r2->vec[i];
        r1->len = r1->len+r2->len;
        r1->vec[r1->len]='\0';
      
    }
}

void main()
{
    /*int i;
    int j;
    int k;*/
    str *r;
    str *r1;
    //str *r2;
    r = (str *) malloc(sizeof(str));
    r1= (str *) malloc(sizeof(str));
    //r2= (str *) malloc(sizeof(str));
    r->len=0;
    r1->len=0;
    //r2->len=0;
    printf("输入第一个字符串:");
    gets(r->vec);
    printf("输入第二个字符串:");
    gets(r1->vec);
    printf("第一个长为%d\n",r->len = lenstr(r));
    printf("第二个长为%d\n",r1->len = lenstr(r1));   
    concatstr(r,r1);
    printf("连接后的串为:");
    puts(r->vec);
}
1