1785题目描述
题目表述有问题,这个题目只是要求连接两个字符串.
不借用任何字符串库函数实现(无冗余地接受)两个字符串,然后把它们(无冗余的)连接起来。
输入
每一行包括两个字符串,长度不超过100。
输出
可能有多组测试数据,对于每组数据,
不借用任何字符串库函数实现无冗余地接受两个字符串,然后把它们无冗余的连接起来。
输出连接后的字符串。
样例输入
abc def
样例输出
abcdef
(1)字符串输出,注意末尾加上’\0’结束标志.strlen(str)返回的长度是不包含’\0’,和最后一个字符后的空字符.
#include <iostream>
#include <string.h>
using namespace std;
int main() {
char str1[101];
char str2[101];
while(scanf("%s %s",str1,str2) != EOF) {
int l = strlen(str1);
for (int i = 0; i < strlen(str2); i++)
str1[l++] = str2[i];
str1[l] = '\0'; //结束标志
cout<<str1<<endl;
}
return 0;
}
(2)字符逐个输出,不用加结束标志.
#include <iostream>
#include <string.h>
using namespace std;
int main() {
char str1[101];
char str2[101];
while(cin>>str1 >>str2) {
int l = strlen(str1);
for (int i = 0; i < strlen(str2); i++)
str1[l+i] = str2[i]; //l+i ;l的值没有变化还是原始长度
// strlen(str1)字符串的最新长度
for(int i=0; i < strlen(str1) ;i++){
cout<<str1[i];
}
cout<<endl;
}
return 0;
}
(3)str1[l++] = str2[i];
#include <iostream>
#include <string.h>
using namespace std;
int main() {
char str1[101];
char str2[101];
while(cin>>str1 >>str2) {
int l = strlen(str1);
for (int i = 0; i < strlen(str2); i++)
str1[l++] = str2[i];
//l的值以更新,不用重新计算str1的长度了
for(int i=0; i < l ;i++){
cout<<str1[i];
}
cout<<endl;
}
return 0;
}