找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 15418|回复: 0

[数值计算] 批处理快速计算勾股素数

[复制链接]
发表于 2009-3-7 20:18:56 | 显示全部楼层 |阅读模式

  1. :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
  2. ::算法原理:http://zh.wikipedia.org/wiki/%E5%8B%BE%E8%82%A1%E6%95%B0
  3. ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
  4. @echo off||Code By plp626
  5. ::勾股数中最小的一个数 < MAX^2 这里暂定MAX=30
  6. set MAX=30 & if not %1.==. goto%*
  7. echo    稍等。。。
  8. for /f "delims=" %%a in ('%~s0 :rtnum^|sort')do echo.%%a
  9. pause&exit/b
  10. :rtnum
  11. setlocal enabledelayedexpansion&set "s=        "
  12. for /l %%n in (1 1 %MAX%)do (set/a tp=%%n+1
  13. for /l %%m in (!tp! 2 %MAX%)do (call:ifprime %%m %%n prm
  14.     if !prm! equ 1 (
  15.       set/a mm=%%m*%%m,nn=%%n*%%n,a=mm-nn,b=2*%%m*%%n,c=mm+nn
  16.         set a=%s%!a!&set b=%s%!b!&set c=%s%!c!
  17.         if !a! lss !b! (echo !a:~-7! !b:~-7! !c:~-7!) else echo !b:~-7! !a:~-7! !c:~-7!
  18. )))
  19. exit/b
  20. :ifprime
  21. set/a x=%1,y=%2
  22. :loop
  23. set/a r=x%%y,x=y,y=r
  24. if %r% neq 0 (goto:loop) else set %3=%x%
复制代码

评分

参与人数 1PB +5 收起 理由
Batcher + 5 感谢分享

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 00:06 , Processed in 0.016118 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表