Why am i getting invalid types float[int] for array subscript?(为什么我得到数组下标的无效类型FLOAT[INT]?)
本文介绍了为什么我得到数组下标的无效类型FLOAT[INT]?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
所以我研究了有关堆栈溢出的其他问题,这些问题似乎描述了相同的问题,但每种情况下的问题似乎都是错误的引用,例如对象不是数组。我想我已经正确地引用了我的数组,但今天是我做C++的第一天。有人能告诉我我做错了什么吗?
#include <Rcpp.h>
#include <cmath>
using namespace Rcpp;
// [[Rcpp::export]]
float convolute2D1(float arr[], int skew) {
int m, n, l, j;
float o;
if (skew < 0) {
m = 1;
n = 2;
skew = abs(skew);
} else {
m = 2;
n = 1;
}
l = *(&arr + 1) - arr;
l = l / 2 - skew;
for(int i = 1; i <= l; i++) {
j = i + skew;
o = o + abs(arr[m][j] - arr[n][j]);
}
return o / l;
}
// END OF SCRIPT
我收到错误:
Line 31 invalid types 'float[int]' for array subscript
Line 31 invalid types 'float[int]' for array subscript
Line 41 expected ',' or '...' before 'SEXP'
Line 45 expected primary-expression before ']' token
line 46 'skewSEXP' was not declared in this scope
Line 47 expected primary-expression before ']' token
推荐答案
您正在传递一个线性数组作为函数的参数,但您正在使用它,就好像它是一个2D数组,这是不可能的。
传递时,arr
只能像arr[i]
,不能像arr[i][j]
。
这篇关于为什么我得到数组下标的无效类型FLOAT[INT]?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:为什么我得到数组下标的无效类型FLOAT[INT]?


基础教程推荐
猜你喜欢
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- C++,'if' 表达式中的变量声明 2021-01-01
- 如何在 C++ 中处理或避免堆栈溢出 2022-01-01
- 设计字符串本地化的最佳方法 2022-01-01
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 运算符重载的基本规则和习语是什么? 2022-10-31
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17