matlab阶乘和程序

functiony=jch(n)y=0;fori=1:nm=factorial(n)y=y+m;end这是我写的M文件当我计算jch(4)时结果答案成了96求大神说下错误... function y=jch(n)
y=0;
for i=1:n
m=factorial(n)
y=y+m;
end

这是我写的M文件 当我计算jch(4)时 结果答案成了96 求大神说下错误并且修正 谢谢了
展开
 我来答
麻木y1
高粉答主

2019-09-17 · 每个回答都超有意思的
知道小有建树答主
回答量:765
采纳率:100%
帮助的人:30.7万
展开全部

matlab程序为:

function jiechenghe=fun(x)

jiechenghe=0;

s=1;

for i=1:x

s=s*i;

jiechenghe=jiechenghe+s;

end

应用:求n!的位数

可以将n!表示成10的次幂,即n!=10^M(10的M次方)则不小于M的最小整数就是 n!的位数,对该式两边取对数,有 M =log10^n!

即:M = log10^1+log10^2+log10^3...+log10^n。循环求和,就能算得M值,该M是n!的精确位数。

扩展资料:

对于复数应该是指所有模n小于或等于│n│的同余数之积,对于任意实数n的规范表达式为:正数 n=m+x,m为其正数部,x为其小数部;负数n=-m-x,-m为其正数部,-x为其小数部。

在 Common Lisp 中, 可以很方便的使用更为简洁的使用递归实现阶乘:

(defun factorial (n)

(cond

((> n 0) (* (factorial (- n 1)) n))

((= n 0) 1)

(t (error "N is smaller than 0."))))

参考资料来源:百度百科-n!

四舍五不入6
高粉答主

2020-03-13 · 还没有填写任何签名哦
四舍五不入6
采纳数:27 获赞数:71405

向TA提问 私信TA
展开全部

首先不含0的阶乘,即:x阶乘和=1!+2!+……+x!;

matlab参考程序为:

functionjiechenghe=fun(x)

jiechenghe=0;

s=1;

fori=1:x

s=s*i;

jiechenghe=jiechenghe+s;

end

若想加入0的阶乘,可以加入判断条件,令0!=1;

MATLAB和Mathematica、Maple并称为三大数学软件。它在数学类科技应用软件中在数值计算方面首屈一指。MATLAB可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等。

扩展资料:

Matlab参考函数

randn()创建随机矩阵,服从正态分布

randperm()创建随机行向量

horcatC=[A,B],水平聚合矩阵,还可以用cat(1,A,B)

vercatC=[A;B],垂直聚合矩阵,还可以用cat(2,A,B)

repmat(M,v,h)将矩阵M在垂直方向上聚合v次,在水平方向上聚合h次

blkdiag(A,B)以A,和B为块创建块对角矩阵

参考资料来源:百度百科-MATLAB

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
刘贺great
2013-07-12 · TA获得超过1.6万个赞
知道大有可为答主
回答量:3829
采纳率:100%
帮助的人:2281万
展开全部
第一,这个有现成的函数,没必要编函数了
第二,要自己编,应该用原始计算
第三,你写得不是阶乘,是阶乘的累加了
function y=jch(n)
y=1;
for ii=1:n
y=y*ii;
end
---------------呵呵,看错了,就是求累加:
function y=jch(n)
for ii=1:n
m(ii)=factorial(ii);
end
y=sum(m);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
央一瑟3
推荐于2017-09-26 · TA获得超过211个赞
知道小有建树答主
回答量:496
采纳率:100%
帮助的人:188万
展开全部
1.首先不含0的阶乘,即:x阶乘和=1!+2!+……+x!;
2.matlab程序为:
function jiechenghe=fun(x)
jiechenghe=0;
s=1;
for i=1:x
s=s*i;
jiechenghe=jiechenghe+s;
end
3.若想加入0的阶乘,可以加入判断条件,令0!=1;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
雨扬振1238
推荐于2017-09-10 · TA获得超过2782个赞
知道小有建树答主
回答量:586
采纳率:100%
帮助的人:1044万
展开全部
你是想求1!+2!+3!+...+(n-1)!+n!吗?
如果是,那么将m=factorial(n)改为m=factorial(i);
现在你应该明白为什么你会得到96,而不是33了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式