我在C++中遇到了这个奇怪的编译错误
I am getting this strange compilation error in C++
我正在做硬币变化问题,我正在尝试使用动态编程来做。但是我得到了这个我不太明白的汇编。有人告诉我,我必须动态分配"dp"数组,但他不知道为什么。请解释这个概念。
#include<bits/stdc++.h>
using namespace std;
int solve(int *d, int size, int n , int ** dp){
if(n==0)
return 1;
if(n<0)
return 0;
if(size == 0)
return 0;
if(dp[n][size]>-1)
return dp[n][size];
int x = solve(d,size,n-d[0],dp);
int y = solve(d+1, size - 1, n, dp );
dp[n][size] = x+y;
return x+y;
}
int countWaysToMakeChange(int denominations[], int numDenominations, int value){
int dp[value+1][numDenominations+1];
memset(dp, -1, sizeof dp);
return solve(denominations, numDenominations, value, dp );
}
错误:
Compilation Failed
In file included from Runner.cpp:3:0:
Solution.h: In function 'int countWaysToMakeChange(int*, int, int)':
Solution.h:28:60: error: cannot convert 'int (*)[(numDenominations + 1)]' to 'int**' for argument '4' to 'int solve(int*, int, int, int**)'
return solve(denominations, numDenominations, value, dp);
^
这是我的主文件代码:
#include<iostream>
using namespace std;
#include "Solution.h"
int main(){
int numDenominations;
cin >> numDenominations;
int* denominations = new int[numDenominations];
for(int i = 0; i < numDenominations; i++){
cin >> denominations[i];
}
int value;
cin >> value;
cout << countWaysToMakeChange(denominations, numDenominations, value);
}
代码中有两个问题。
首先,在函数int countWaysToMakeChange(int denominations[], int numDenominations, int value)
int dp[value+1][numDenominations+1];
是非法的。数组边界必须是编译时常量。一些编译器允许这种东西作为扩展(这在 C 中是合法的(,但它在C++是无效的。
其次,dp
的类型是"int
数组的数组"。它不是"指向int
的指针",编译器抱怨当代码尝试将dp
作为第四个参数传递给solve
时,它无法进行该转换。
数组令人困惑。在大多数上下文中,数组的名称衰减为指向其第一个元素的指针。这就是为什么你可以像这样编写代码:
void f(int*);
void g() {
int array[20];
f(array);
}
由于dp
是一个数组,因此它的名称衰减为指向其第一个元素的指针。但这是很容易迷路的地方:正如我之前所说,dp
的类型是"int
数组";当其名称衰减时,生成的类型是"指向int
数组的指针"。
如果要将dp
传递给solve
,solve
必须采用相同的类型:"指向int
数组的指针"。但是,由于您在编写solve
时不知道该数组的大小,因此您无法在参数列表中写入该类型。
这就是为什么多维数组通常表示为一维数组的原因之一,使用代码将二维转换为一维。偏移量是x * width + y
,或者一些次要的变体。当你这样做时,你的二维数组就变成了一个一维数组,它的名字会衰减成一个指向它的第一个元素的指针,所以你可以把它传递给一个需要int*
的函数。
相关文章:
- std::is_base_of表示ctor编译错误
- Qt5:使用QCommandLineParser类时出现奇怪的编译错误
- 如何修复sfml c++代码编译错误
- 使用 MATLAB 编码器生成C++代码:编译错误"undefined reference to `rgb2gray_tbb_real64'"
- 使用外部SDK工具链文件在VisualStudio上生成项目编译错误
- vscode下的Arduino代码出现意外编译错误
- 第三方 API 中的编译错误 - Visual Studio
- std::cout输出int时出现编译错误
- 奇怪的代码抛出编译错误模板< J,int aSize=10> C2143:语法错误:在"<"之前缺少";"
- 提升图广度优先搜索前置编译错误
- C++ 中的编译错误:未定义对"主"的引用 collect2:错误:ld 返回 1 个退出状态
- 使用带有 ref 参数的成员函数创建线程时出现编译错误
- 我在C++中遇到了这个奇怪的编译错误
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- 使用 std::enable_if 限制派生类的模板参数时出现编译错误
- 现代OpenGL和GLEW Libraray的编译错误
- C++ 编译错误:意外的类型名称"字符串":预期的表达式
- C ++程序编译错误,找不到/访问文件
- 使用直接大括号初始化时,C++ 编译错误"声明末尾的预期";"
- 为什么传递非静态成员函数会导致编译错误?