我正在尝试遍历未知大小的double
数组。
为什么以下不起作用?
for (unsigned int = 1; i < sizeof(anArray)/sizeof(double); i++) {
...
}
所有内容编译都很好(g++ -Wall -Werror -std=c++11 app.cpp -o app
),但程序根本不进入循环。
全功能:
struct stock_data {
int sell_index;
int buy_index;
double profit;
};
stock_data max_profit(double price_array[]) {
int sell_index = -1, buy_index = -1,
min = 0;
double profit = 0.0;
for(int i = 1; i < size; i++) {
if(price_array[i] - price_array[min] > profit) {
sell_index = min;
buy_index = i;
profit = price_array[i] - price_array[min];
}
if(price_array[i] < price_array[min]) {
min = i;
}
}
return {sell_index, buy_index, profit};
}
int main() {
double yesterday[] = {0.1, 0.2, 0.3, 0.4};
stock_data data = max_profit(yesterday);
cout << data.profit << endl;
}
答案 0 :(得分:5)
在C ++中,运算符sizeof是一个编译时运算符。也就是说,它的值是由编译器在运行时计算的。
因此,如果您说数组的大小未知,则编译器无法计算数组占用的内存大小。
很明显,anArray是指向可能传递给函数的数组的第一个元素的指针。
因此这个表达
sizeof(anArray)/sizeof(double)
相当于表达式
sizeof( double * )/sizeof( double ).
您还必须将数组的大小显式传递给函数。
考虑到通过值传递给函数的数组将转换为指向其第一个元素的指针。
或者另一种方法是使用conteiner std::vector<double>
而不是数组。
您可以声明您的功能
stock_data max_profit(double price_array[], size_t size );
并将其称为
stock_data data = max_profit( yesterday,
sizeof( yesterday ) / sizeof( *yesterday ) );
答案 1 :(得分:3)
sizeof(anArray)
返回anArray
类型的大小,可能是*double
。您必须将数组大小作为附加参数传递,或使用std::vector
及其size
方法。
查看C main函数main(argc, argv)
,其中argv
是程序的参数,argc
是它们的计数。或者取字符串,它们的结束由确定其结尾的特殊字符\ 0确定。但这很容易出错。
在C / C ++中,没有其他方法可以使用数组。
答案 2 :(得分:1)
您的函数max_profit
不知道数组price_array
的大小。
如果希望函数接受不同大小的数组,则有两个选项:
size
值与数组一起传递(C样式)std::vector
内置(C ++样式)size
对象
答案 3 :(得分:1)
如果你真的想避免传递大小,你可以在数组的末尾添加一个NaN并在循环中检查它。
#include<cmath>
...
for(int i = 0; !isnan(price_array[i]; i++){
...
}
在您声明数组时添加NaN:
double price_array{0.0d, 5.9d, nan()};
当然,这假设您在阵列中没有任何其他NaN作为实际数据的一部分。