题目描述
不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来。
输入描述:
每一行包括两个字符串,长度不超过100。
输出描述:
可能有多组测试数据,对于每组数据,
不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来。
输出连接后的字符串。
示例1
输入
复制
abc def
输出
复制
abcdef
开始的代码没有想到无冗余
#include <stdio.h>
int main(){
char str1[100],str2[100],str3[303];
while(scanf("%s%s",&str1,&str2)!=EOF){//scanf("%s")识别空格和换行
int i,j;
for(i=0;str1[i]!='\0';i++){//字符串数组以'\0'为结尾
str3[i]=str1[i];
}
for(j=0;str2[j]!='\0';j++){//字符串数组以'\0'为结尾
str3[j+i]=str2[j];
}
str3[i+j] ='\0'; //勿忘加'\0'
printf("%s",str3);
}
return 0;
}
后来看到牛客网上一位大神yyywwww的解答
无冗余不能用数组 而用malloc和realloc
贴上代码
链接:https://www.nowcoder.com/questionTerminal/40d83e5509b04d20825ae68fe35e9ca8
来源:牛客网
#include <stdio.h>
#include <stdlib.h>
//不使用字符串库函数就是说用char
//无冗余那就不能用数组
//那么只能用malloc和realloc了
int main(int argc,const char * argv[])
{
int i = 1,j=1,k;
char * p1 = (char *)malloc(sizeof(char));
char * p2 = (char *)malloc(sizeof(char));
char a;
while((a = getchar())!=' ')
{
p1 = (char *)realloc(p1,sizeof(char)*i);
*(p1+i-1) = a;
i++;
}
p1 = (char *)realloc(p1,sizeof(char)*i);
*(p1+i-1) = '\0';
while((a = getchar())!='\n')
{
p2 = (char *)realloc(p2,sizeof(char)*j);
*(p2+j-1) = a;
j++;
}
p2 = (char *)realloc(p2,sizeof(char)*j);
*(p2+j-1) = '\0';
p1 = (char *)realloc(p1,sizeof(char)*(i+j-1));
for(k = 0;k<j;k++,i++){
*(p1+i-1) = *(p2+k);
}
printf("%s",p1);
free(p2);
free(p1);
return 0;
}