#include<stdio.h>
#include<stdlib.h>
void main()
{
int n,i,j,s,k,u;
FILE *fp1,*fp2;
char ch[100],a[100],b[100];
printf("输入字符串的长度:");
scanf("%d",&n);
for(i=0;i<n+1;i++)
{
scanf("%c",&ch[i]);
}
fp1=fopen("D:\a.txt","w");
if(fp1==NULL)
{
printf("can not open the file\n");
exit(0);
}
for(i=0;i<n+1;i++)
{
fprintf(fp1,"%c",ch[i]);
}
fclose(fp1);
printf("被连接的字符串长度:\n");
scanf("%d",&u);
for(i=0;i<u;i++)
{
scanf("%c",&b[i]);
}
for(j=0,s=0;j<n+1;j++)
{
a[s]=ch[j];
s++;
}
for(j=0,s;j<u+1;j++)
{
a[s]=b[j];s++;
}
fp1=fopen("D:\a.txt","r");
fp2=fopen("D:\b.txt","w");
if(fp2==NULL)
{
printf("can not open the file\n");
exit(0);
}
for(k=0;k<n+u+2;k++)
{
fprintf(fp2,"%c",a[k]);
}
fclose(fp1);
fclose(fp2);
}
我去试试
#include<stdio.h>
#include<stdlib.h>
int main()
{
int n,i,j,s,k,u;
FILE *fp1,*fp2;
char ch[100],a[100],b[100];
printf("输入字符串的长度:");
scanf("%d",&n);
getchar();
for(i=0;i<n;i++)
{
scanf("%c",&ch[i]);
}
fp1=fopen("123.txt","w");
for(i=0;i<n;i++)
{
fprintf(fp1,"%c",ch[i]);
}
fclose(fp1);
printf("被连接的字符串长度: ");
scanf("%d",&u);
getchar();
for(i=0;i<u;i++)
{
scanf("%c",&b[i]);
}
for(j=0,s=n;j<u;j++)
{
ch[s]=b[j];s++;
}
fp1=fopen("123.txt","r");
fp2=fopen("234.txt","w");
for(k=0;k<n+u;k++)
{
fprintf(fp2,"%c",ch[k]);
}
fclose(fp1);
fclose(fp2);
system("pause");
return 0;
}
现在应该好了
主要问题是你scanf读取数据的时候没有考虑它读进回车的情况,用一下getchar就好了。
还有一个小问题是以后代码尽量不要用这么多变量,稍微有点难读懂啊兄弟
如果还有问题麻烦追问
输出的那个数组越界了是不是,把数组长度拉大呢。
数组长度是n,结果你取值从0-n共n+1个数,没给你报错就不错了
for(i=0;i<n+1;i++)改成for(i=0;i<n;i++)就可以了吧。