33 const std::string max_subarray_sum_program =
35 " var curr_sum := 0; "
36 " var curr_start := 0; "
38 " for (var i := 0; i < vec[]; i += 1) "
40 " curr_sum += vec[i]; "
42 " if (curr_sum < zero) "
45 " curr_start := i + 1; "
47 " else if (curr_sum > max_sum) "
49 " max_sum := curr_sum; "
50 " max_start := curr_start; "
59 T vec[] = { T(-1), T(-2), T(3), T(5), T(6), T(-2), T(-1), T(4), T(-4), T(2), T(-1) };
61 symbol_table_t symbol_table;
63 symbol_table.add_variable(
"max_sum" , max_sum );
64 symbol_table.add_variable(
"max_start", max_start);
65 symbol_table.add_variable(
"max_end" , max_end );
66 symbol_table.add_vector (
"vec" , vec );
68 expression_t expression;
69 expression.register_symbol_table(symbol_table);
72 parser.compile(max_subarray_sum_program,expression);
76 if (max_start <= max_end)
78 printf(
"Max sum: %10.3f \n", max_sum);
79 printf(
"Start index: %4d\n",
static_cast<int>(max_start));
80 printf(
"End index: %4d\n",
static_cast<int>(max_end ));
82 for (
int i =
static_cast<int>(max_start); i <= static_cast<int>(max_end); ++i)
84 printf(
"%5.3f ",vec[i]);
90 printf(
"No maximum sum found.\n");