递归公式 Pc,t = 0.88 * Pc-1,t + 0.12 * Pc-1,t-1 程序如下: function [p] = diguihashu(c,t) if nargin==0, c=1;t=0; end ct=[c,t]; action_ct=num2str(ct); switch(action_ct) case '1 1' p=0.12; case action_ct temp=str2num(action_ct); cc=temp(1);tt=temp(2); if tt==0||cc
p=0; else p=0.88*diguihashu(c-1,t)+0.12*diguihashu(c-1,t-1); end otherwise, error('Unkonwn acction string!'); end %测试结果: >> pct=diguihashu(12,5) pct = 0.0034 %下面是画图程序: clear p=zeros(15,15); for c=1:15 for t=1:15 p(c,t)=diguihashu(c,t); end end [cc,tt]=meshgrid(1:15,1:15); surf(cc,tt,p) xlabel('c') ylabel('t') MATLAB是美国MathWorks公司出品的商业数学软件,用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境,主要包括MATLAB和Simulink两大部分。 MATLAB是matrix&laboratory两个词的组合,意为矩阵工厂(矩阵实验室)。是由美国mathworks公司发布的主要面对科学计算、可视化以及交互式程序设计的高科技计算环境。它将数值分析、矩阵计算、科学数据可视化以及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平。 MATLAB和Mathematica、Maple并称为三大数学软件。它在数学类科技应用软件中在数值计算方面首屈一指。MATLAB可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。 MATLAB的基本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成相同的事情简捷得多,并且MATLAB也吸收了像Maple等软件的优点,使MATLAB成为一个强大的数学软件。在新的版本中也加入了对C,FORTRAN,C++,JAVA的支持。
其中c是自变量,范围(1,201),步长为1,Pc,t为函数值(c,t为P的下标)。且P1,1=0.12, Pc,0=0; 当c
main.m
N=106;
K=sum1(N);
K=K*sqrt(3);
Sum1.m
function [K]=sum1(N)
if N-1>0
K=sum1(N-1)+cal(N);
elseif N==1
K=cal(1);
end
cal.m
function [K]=cal(N)
if N==0
K=1;
elseif N>0
K=1/2*cal(N-1);
end