[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
看了半天,后面全部离题了。。。

所谓的“正算反算”应该是 nx=n*n 之后,再求 n <> nx/n  的循环次数。

一个数乘了以后如果溢出,那么反过来这个溢出数除了之后肯定不等于原来的数了。

TOP

代码放上
  1. @echo off
  2. set /p in=请输入正整数:
  3. set /a inx=in
  4. for /l %%i in (1,1,100) do (
  5. 2>nul  set /a ix=inx*in,"1/!(ix / inx - in)",inx=ix ||call :end %%i
  6. )
  7. :end
  8. echo %in%的%1次方接近于CMD最大值,值为%inx%。
  9. pause>nul&exit
复制代码
1

评分人数

TOP

判断是否2的倍数,只要知道最后一个字节是0是1就可以了。

哪怕最直接的 % 2 ,求余数都比你那个复杂的计算要快。

TOP

本帖最后由 caruko 于 2011-5-17 20:47 编辑

才发现这道题是两年前的。。。

把我前面43#的代码做了精简。
去掉了CALL
  1. @echo off
  2. set /p in=请输入整数:
  3. set /a inx=in,flag=1&for /l %%i in (1,1,30) do (
  4. 2>nul set /a 1/flag,cs=%%i,ix=inx*in,"1/!(ix / inx - in)",inx=ix ||set flag=0)
  5. echo %in%的%cs%次方接近于CMD最大值,值为%inx%。
  6. pause>nul
复制代码

TOP

返回列表