代码清单1-10
int[V + 1][T + 1] opt;  	// 子问题的记录项表,假设从i到T种饮料中,
                            	// 找出容量总和为V'的一个方案,满意度最多能够达到
                           	// opt(V',i,T-1),存储于opt[V'][i],
                           	// 初始化时opt中存储值为-1,表示该子问题尚未求解。
int Cal(int V, int type)
{
     if(type == T)
     {
          if(V == 0)
              return 0;
          else
              return -INF;
     }
     if(V < 0)
          return -INF;
     else if(V == 0)
          return 0;
     else if(opt[V][type] != -1)
          return opt[V][type]; 	// 该子问题已求解,则直接返回子问题的解;
                                 	// 子问题尚未求解,则求解该子问题
     int ret = -INF;
     for(int i = 0; i <= C[type]; i++)
     {
          int temp = Cal(V – i * C[type], type + 1);
          if(temp != -INF)
          {
              temp += H[type] * i;
              if(temp > ret)
                   ret = temp;
          }

     }
     return opt[V][type] = ret;
}