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};