中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 【分享】bat递归的"917“新发现
作者:
标题: 【分享】bat递归的"917“新发现 上一主题 | 下一主题
plp626
银牌会员

钻石会员


积分 2278
发帖 1020
注册 2007-11-19
状态 离线
『楼 主』:  【分享】bat递归的"917“新发现

命令行下键入
f 1000 ans
echo %ans%
以下代码保存为f.bat
:f //求%1的阶乘 [integer] [%2]
@set/a n=%1-1
@if %1==0 (set/a %2=1) else (call:f %n% m&set/a %2=%1*m)
[ Last edited by plp626 on 2009-4-10 at 14:11 ]



山外有山,人外有人;低调做人,努力做事。

进入网盘(各种工具)~~ 空间~~cmd学习
2009-4-10 14:09
查看资料  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 2 楼』:  

真不敢运行
话说高人的代码向人来高深莫测




有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-4-10 17:23
查看资料  发短消息 网志   编辑帖子  回复  引用回复
knoppix7
银牌会员





积分 1287
发帖 634
注册 2007-5-2
来自 cmd.exe
状态 离线
『第 3 楼』:  

来回Call的话就会这样.

Call有限制的..

2009-4-10 22:20
查看资料  发短消息 网志   编辑帖子  回复  引用回复
Pierre
初级用户





积分 30
发帖 19
注册 2009-4-4
状态 离线
『第 4 楼』:  

H:\Documents and Settings\Pierre>f 1000 ans
******  B A T C H   R E C U R S I O N  exceeds STACK limits ******
Recursion Count=619, Stack Usage=90 percent
******       B A T C H   PROCESSING IS   A B O R T E D      ******

2009-4-11 01:11
查看资料  发短消息 网志   编辑帖子  回复  引用回复
Pierre
初级用户





积分 30
发帖 19
注册 2009-4-4
状态 离线
『第 5 楼』:  

620就超出了,看来最多619
而实际上超过33就不能算了,而32和33都是-2147483648

2009-4-11 01:14
查看资料  发短消息 网志   编辑帖子  回复  引用回复
chenall
银牌会员




积分 1276
发帖 469
注册 2002-12-23
来自 福建泉州
状态 离线
『第 6 楼』:  

由于CMD下
数字精确度限为 32 位.
所以最多到33就不能计算了,超出最大值.



QQ:366840202
http://chenall.net
2009-4-11 05:22
查看资料  发送邮件  访问主页  发短消息 网志  OICQ (366840202)  编辑帖子  回复  引用回复
plp626
银牌会员

钻石会员


积分 2278
发帖 1020
注册 2007-11-19
状态 离线
『第 7 楼』:  



  Quote:
Originally posted by Pierre at 2009-4-11 01:14 AM:
620就超出了,看来最多619
而实际上超过33就不能算了,而32和33都是-2147483648

你这是个什么系统,怎么会是619呢?


******  B A T C H   R E C U R S I O N  exceeds STACK limits ******
Recursion Count=917, Stack Usage=90 percent
******       B A T C H   PROCESSING IS   A B O R T E D      ******




山外有山,人外有人;低调做人,努力做事。

进入网盘(各种工具)~~ 空间~~cmd学习
2009-4-11 07:55
查看资料  发短消息 网志   编辑帖子  回复  引用回复
不得不爱
超级版主

我爱DOS


积分 5310
发帖 2044
注册 2005-9-26
来自 四川南充
状态 离线
『第 8 楼』:  



  Quote:
Originally posted by Pierre at 2009-4-11 01:14:
620就超出了,看来最多619
而实际上超过33就不能算了,而32和33都是-2147483648

我也是递归到917就后就报错了


而上面的计算方法中n!结算到 13!就已经溢出了,超过12阶后计算出来的都是错误的!



我的网络U盘 我的网络第2个U盘
论坛软件下载链接
灵雨飘零论坛  
论坛新手必读,所有人的基本行为准则
刷QQ空间人气、留言的小软件
2009-4-12 07:55
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
不得不爱
超级版主

我爱DOS


积分 5310
发帖 2044
注册 2005-9-26
来自 四川南充
状态 离线
『第 9 楼』:  

我刚才试了下递归层数好像还跟什么有关系,如下面的
@echo off
:aa
call :aa a
******  B A T C H   R E C U R S I O N  exceeds STACK limits ******
Recursion Count=1240, Stack Usage=90 percent
******       B A T C H   PROCESSING IS   A B O R T E D      ******

说明最大递归次数是1240

[ Last edited by 不得不爱 on 2009-4-12 at 08:19 ]



我的网络U盘 我的网络第2个U盘
论坛软件下载链接
灵雨飘零论坛  
论坛新手必读,所有人的基本行为准则
刷QQ空间人气、留言的小软件
2009-4-12 08:14
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
freeants001
中级用户




积分 330
发帖 244
注册 2006-4-14
来自 湖北
状态 离线
『第 10 楼』:  

******  B A T C H   R E C U R S I O N  exceeds STACK limits ******
Recursion Count=917, Stack Usage=90 percent
******       B A T C H   PROCESSING IS   A B O R T E D      ******
917;)

2009-4-12 09:00
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
plp626
银牌会员

钻石会员


积分 2278
发帖 1020
注册 2007-11-19
状态 离线
『第 11 楼』:  



  Quote:
Originally posted by 不得不爱 at 2009-4-12 07:55 AM:

我也是递归到917就后就报错了


而上面的计算方法中n!结算到 13!就已经溢出了,超过12阶后计算出来的都是错误的!

我只是举了个递归简单的例子,超过13当然作为阶乘的结果都是错误的
其实在cmd里没有溢出一说,他只是循环移位,不管数值范围。
:a
call:a a
这个例子更简洁,好!

不过也不知道为什么是1240了



山外有山,人外有人;低调做人,努力做事。

进入网盘(各种工具)~~ 空间~~cmd学习
2009-4-12 10:48
查看资料  发短消息 网志   编辑帖子  回复  引用回复
Pierre
初级用户





积分 30
发帖 19
注册 2009-4-4
状态 离线
『第 12 楼』:  

2003 r2 ent x64

2009-4-12 13:57
查看资料  发短消息 网志   编辑帖子  回复  引用回复
everest79
金牌会员

一叶枝头,万树皆春



积分 2564
发帖 1127
注册 2006-12-25
状态 离线
『第 13 楼』:  

阀值应是2480吧
递归有进有出的
这应跟线程的页面文件或内存分配有关



49206C6F766520796F752067757973 54656C3A3133383238343036373837
2009-4-12 22:20
查看资料  发短消息 网志   编辑帖子  回复  引用回复
523066680
银牌会员

SuperCleaner


积分 2362
发帖 1133
注册 2008-2-2
状态 离线
『第 14 楼』:  

啥? 我的这样
******  B A T C H   R E C U R S I O N  exceeds STACK limits ******
Recursion Count=1240, Stack Usage=90 percent
******       B A T C H   PROCESSING IS   A B O R T E D      ******



综合型编程论坛

我的作品索引
  
2009-10-14 20:04
查看资料  发送邮件  访问主页  发短消息 网志  OICQ (523066680)  编辑帖子  回复  引用回复
523066680
银牌会员

SuperCleaner


积分 2362
发帖 1133
注册 2008-2-2
状态 离线
『第 15 楼』:  

有一个好像可以超越call层次的方法
建立一个xxx.bat

代码为
echo %1
xxx a
好像返回的时候环境不能恢复……多此一举了

[ Last edited by 523066680 on 2009-10-14 at 20:44 ]



综合型编程论坛

我的作品索引
  
2009-10-14 20:07
查看资料  发送邮件  访问主页  发短消息 网志  OICQ (523066680)  编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: