[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
设捕鱼总数为 R_0, 第 i 个人分鱼后的剩余数为 R_i, 则有:
R_i = R_(i+1) * 5 / 4 + 1
R_1, R_2, R_3, R_4, R_5 皆为 4 的倍数.

将 R_5 从 0 开始测试, 如计算得出 R_1, R_2, R_3, R_4 皆为 4 的倍数, 则得最小解;
否则, 将 R_5 增长步长 4, 再次测试...
  1. @echo off
  2. setlocal enableDelayedExpansion
  3. set /a R_5 = 0
  4. :loop
  5. set /a check = 0
  6. for /l %%i in (4 -1 0) do (
  7.   set /a j = %%i + 1
  8.   for %%j in (!j!) do set /a "R_%%i = R_%%j * 5 / 4 + 1"
  9.   if %%i gtr 0 set /a "check |= R_%%i & 3"
  10. )
  11. if !check! neq 0 (
  12.   set /a R_5 += 4
  13.   goto :loop
  14. )
  15. set R_
  16. pause
复制代码

TOP

返回列表