错误:将'char*'分配给'char [4000]'的类型不兼容
error: incompatible types in assignment of 'char*' to 'char [4000]'
我一直在努力解决一个简单的问题,但我不明白为什么我的程序不起作用。我想连接一个字符串。你能帮我吗?如果是,你能解释一下为什么它不起作用吗?
#include <iostream>
#include <cstring>
#include <fstream>
using namespace std;
ifstream in("sirul.in");
ofstream out("sirul.out");
char a[4000]="a",b[4000]="b",aux[4000];
int main()
{ int n,i;
in>>n;
if(n==1)out<<"a";
if(n==2)out<<"b";
for(i=3;i<=n;i++)
{
aux=strcpy(aux,b);
b=strcat(b,a);
a=strcpy(a,aux);
}
return 0;
}
strcpy
和strcat
直接作用于作为第一个参数传入的指针,然后还返回is,以便可以连锁调用。因此,将结果分配回目标指针是多余的。在这种情况下,它也是无效的,因为您无法重新分配数组。
修复方法是不分配这些调用的返回值:
strcpy(aux,b);
strcat(b,a);
strcpy(a,aux);
但是,由于您使用的是C++,因此应该使用std::string
,这为字符串数据提供了很好的值语义。
你不能做(见2(
char b[4000]="b";
char aux[4000];
aux /* 2 */ = strcpy(aux /* 1 */ , b);
因为aux不是指针,而是数组。您可以将其作为指针参数传递(请参见1(,但不能"收集"aux内部的结果(请参见2(。
正如其他人建议的那样,只需删除"集合",它就会如您所期望的那样工作。
char b[4000]="b";
char aux[4000];
strcpy(aux /* 1 */ , b);
// or even:
const char *s = strcpy(aux /* 1 */ , b);
此外,您正在将C和C++混合在一个文件中。
也可能存在缓冲区溢出的可能性。
#include <iostream>
#include <cstring>
#include <fstream>
using namespace std;
ifstream in("sirul.in");
ofstream out("sirul.out");
char a[4000]="a",b[4000]="b",aux[4000];
int main()
{
int n,i;
cin>>n;
if(n==1)cout<<"a";
if(n==2)cout<<"b";
for(i=3;i<=n;i++)
{
strcpy(aux,b);
strcat(b,a);
strcpy(a,aux);
}
return 0;
}
签出定义为strcpy,in应为cin,out应为cout