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

[其他] [分享]批处理版数字魔术揭秘

[复制链接]
发表于 2012-3-30 11:45:45 | 显示全部楼层 |阅读模式
  1. @echo off&setlocal enabledelayedexpansion&mode con cols=48 lines=20
  2. echo;心里想一个1-63之间的整数
  3. for /l %%i in (1 1 63) do (
  4.     set S=%%i
  5.     for /l %%j in (6 -1 1) do (
  6.         set/a "$N=S&1,S>>=1,N/=$N" 2>NUL&&SET _%%j=!_%%j! %%i
  7.    )
  8. )
  9. for /l %%i in (1 1 6) do (
  10.     set IN=&echo;&echo;!_%%i!&echo;!.%%i!
  11.     ECHO;如果上面数列中出现你所想的那个数请键入Y后按回车:
  12.     ECHO;&ECHO;如果数列中没有你所想的那个数请直接按回车:
  13.     set/PIN=
  14.     set /A "Y=64>>%%i,N+=!IN!" 2>NUL
  15.     cls
  16. )
  17. ECHO;&ECHO;        你所想的数是: !N!
  18. ECHO;&pause
复制代码

评分

参与人数 1PB +6 技术 +1 收起 理由
CrLf + 6 + 1 给力

查看全部评分

发表于 2012-3-30 12:50:56 | 显示全部楼层
本帖最后由 fatcat 于 2012-3-30 14:16 编辑

[1,63] 是除 0 之外的所有 6 位的无符号数,
前段代码将这 63 个数按规则(满足共同特征的所有数)取出 31 个 组成 6 个不同的组(互有交集),
第 1 组的共同特征为 第 5 位(从右至左, 位依次编号 0,1,2,3,4,5)都是 1;
第 2 组的共同特征为 第 4 位都是 1;
第 3 组的共同特征为 第 3 位都是 1;
...
第 6 组的共同特征为 第 0 位都是 1;

后段代码给出 6 次询问, 每一次询问确定 1 个位的状态, 6 次询问完毕, 6 个位上的状态就完全确定, 所以答案就被确定.

评分

参与人数 1技术 +1 收起 理由
CrLf + 1 顶一个

查看全部评分

发表于 2012-3-30 13:32:25 | 显示全部楼层
本帖最后由 fatcat 于 2012-3-30 14:26 编辑

6 组数的等效生成代码:
  1. for /l %%b in (1 1 6) do for /l %%i in (1 1 0x3f) do (
  2.   set /a "r=(0x40>>%%b&%%i)<<%%b<<25" & if !r! lss 0 set _%%b=!_%%b! %%i
  3. )
复制代码
发表于 2012-3-30 15:51:05 | 显示全部楼层
为什么是1-63呢?猜想是32 16 8 4 2 1这样的二分搜索,6次即可定位该数。
发表于 2012-3-30 16:12:26 | 显示全部楼层
回复 4# plp626

如果减小规模到 2 位二进制数, 就变成:
第 1 组数: 2 3    (位: 10 11 高位都是 1)
第 2 组数: 1 3    (位: 01 11 低位都是 1)
两次询问与答案的关系:
1 2 答案
y n 2
y y 3
n y 1
n n 0  询问完毕没看到的数, 即所有位都是 0, 当然就是 0 了.
 楼主| 发表于 2012-3-30 18:23:14 | 显示全部楼层
回复 4# plp626
1-63 是因为 63为6位2进制数  当然可以类推至127 那样的话 现在的6组也相应的提升至7组
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-18 21:12 , Processed in 0.015142 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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