void interCross(char s1[], char s2[], char s3[]),将s1和s2中的字符串交叉复制到s3中,构成一个新的字符串。我的输出结果是s1=...s2=...s3=...烫烫烫烫烫烫烫烫烫烫??这是怎么回事??

void interCross(char s1[], char s2[], char s3[]),将s1和s2中的字符串交叉复制到s3中,构成一个新的字符串。我的输出结果是s1=...s2=...s3=...烫烫烫烫烫烫烫烫烫烫??这是怎么回事??

问题描述:

#include
using namespace std;
void interCross (char s1[],char s2[],char s3[])
{
int i,j=0;
for (i=0;i<101; )
{ if (s1[j]=='\0' && s2[j]=='\0') {s3[i]='\0';break;}
else{
if (s1[j]!='\0') {s3[i]=s1[j];i++;}
if (s2[j]!='\0') {s3[i]=s2[j];i++;}
}
j++;
}
}

int main()
{
char s1[100],s2[100],s3[100];
cout<<"输入一串字符得到s1"<<endl;
cin.getline(s1,101);
cout<<"输入一串字符得到s2"<<endl;
cin.getline(s2,101);
cout<<"s1="<<s1<<endl;
cout<<"s2="<<s2<<endl;
interCross(s1,s2,s3);
cout<<"s3="<<s3<<endl;
return 0;
}

因为你的判断条件有问题哦,

数组当中都只有结尾存在一个\0,你如果判断两个数组同时为\0,而你输入的两个数组长度不同的时候,你实际是没有把\0加到s3数组后面的,只能由系统自动运行直到找到\0为止。

建议你不要用\0来判断,用j>strlen(s)来判断数组是否结束复制。
图片说明

图片说明

我运行怎么可以呢

数组没有初始化,原来的地址有垃圾数据;

#include <string.h>

char s1[100],s2[100],s3[100];
memset(s1,0x0,100);
memset(s2,0x0,100);
memset(s3,0x0,100);

char s1[100]={0},s2[100]={0},s3[100]={0};