循环通过未知大小的C ++数组

时间:2015-02-27 05:14:57

标签: c++ arrays for-loop

我正在尝试遍历未知大小的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;
}

4 个答案:

答案 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作为实际数据的一部分。

相关问题