错误:将'char*'分配给'char [4000]'的类型不兼容

error: incompatible types in assignment of 'char*' to 'char [4000]'

本文关键字:char 4000 类型 不兼容 错误 分配      更新时间:2023-10-16

我一直在努力解决一个简单的问题,但我不明白为什么我的程序不起作用。我想连接一个字符串。你能帮我吗?如果是,你能解释一下为什么它不起作用吗?

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

strcpystrcat直接作用于作为第一个参数传入的指针,然后还返回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