function Q=ActionValue(lambda, R, Q0, Q0next, Q0prev, Q0last, Q1, Q1next, Q1prev, Q1last,  gamma)

V=zeros(1, length(R));
Q=zeros(length(R), 2);
iteration=500;
for k=1:iteration
for i=1:length(R)
    if i==1
    Q(i, 1)=R(i)+gamma*(Q0*V(1)+Q0prev*V(1)+Q0next*V(2)+Q0last*V(length(R)));
    Q(i, 2)=R(i)+gamma*(Q1*V(1)+Q1prev*V(1)+Q1next*V(2)+Q1last*V(length(R)))-lambda;
    elseif i==length(R)
    Q(i, 1)=R(i)+gamma*(Q0*V(length(R))+Q0prev*V(length(R)-1)+Q0next*V(length(R))+Q0last*V(length(R)));
    Q(i, 2)=R(i)+gamma*(Q1*V(length(R))+Q1prev*V(length(R)-1)+Q1next*V(length(R))+Q1last*V(length(R)))-lambda;
    else
    Q(i, 1)=R(i)+gamma*(Q0*V(i)+Q0prev*V(i-1)+Q0next*V(i+1)+Q0last*V(length(R)));
    Q(i, 2)=R(i)+gamma*(Q1*V(i)+Q1prev*V(i-1)+Q1next*V(i+1)+Q1last*V(length(R)))-lambda;
    end
    V(i)=max(Q(i, 1), Q(i, 2));
end 
v(1,k)=V(1);
v(2,k)=V(2);
end
% figure(1)
% plot(v(1,:));
% figure(2)
% plot(v(2,:));

