Problem Description
给定两个字符串string1和string2,将字符串string2连接在string1的后面,并将连接后的字符串输出。
连接后字符串长度不超过110。
Input
输入包含多组数据,每组测试数据包含两行,第一行代表string1,第二行代表string2。
Output
对于每组输入数据,对应输出连接后的字符串,每组输出占一行。
Sample Input
123 654 abs sfg
Sample Output
123654 abssfg
#include <stdio.h>
#include <stdlib.h>
#define max 111
typedef struct
{
char *ch;
int length;
}String;//串的定义
void Initstring(String *S)
{
S->ch=(char *)malloc(max*sizeof(char));
if(!S->ch) exit(0);
S->length=0;
}//串的初始化
void StrAssign(String *S,char str[])
{
int i,len=0;
for(i=0;str[i]!='\0';i++)
{
S->ch[len++]=str[i];
}
S->length=len;
}//串赋值,生成值为char str的串S
void f(String *T,String *S1,String *S2)
{
int i,t=0;
for(i=0;i<=S1->length-1;i++) T->ch[t++]=S1->ch[i];
for(i=0;i<=S2->length-1;i++) T->ch[t++]=S2->ch[i];
T->length=t;
}//串连接,用T返回S1+S2的新串
void print(String *T)
{
int i;
for(i=0;i<=T->length-1;i++)
printf("%c",T->ch[i]);
printf("\n");
}//输出串
int main()
{
char str1[10001],str2[10001];
String T,S1,S2;
while(scanf("%s%s",str1,str2)!=EOF)
{
Initstring(&S1);//串的初始化
StrAssign(&S1,str1);//串赋值
Initstring(&S2);//串的初始化
StrAssign(&S2,str2);//串赋值
Initstring(&T);//串的初始化
f(&T,&S1,&S2);//串连接
print(&T);//输出串
}
return 0;
}