明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1639|回复: 1

随机获取表中的对象

[复制链接]
发表于 2010-1-20 10:28:00 | 显示全部楼层 |阅读模式

调用此函数可以模拟掷毂子和洗扑克牌

(defun randGetObj (alist / int int0 int1 second n item)
  (if (not (listp alist))
    (progn
      (princ "\n参数类型错误!")
      (quit)
    )
  )
  (if (or (< (length alist) 2) (> (length alist) 60000))
    (progn
      (princ "\n参数表中的元素太多或太少了")
      (quit)
    )
  )
  (setq int (length alist))
  (setq int0 (fix (/ 60000 int))
 int0 (* int0 int)
 int0 (1- int0)
  )
  (setq second (read (menucmd "M=$(edtime,$(getvar,date),ss.MSEC)"))
 int1   (* second 1000)
 n      1
  )
  (while (and (< n 10) (< int0 int1))
    (setq second (read (menucmd "M=$(edtime,$(getvar,date),ss.MSEC)"))
   int1  (* second 1000)
   n  (1+ n)
    )
  )
  (if (= n 10)
    (setq int1 0)
  )
  (setq item (fix (rem int1 int)))
  (nth item alist)
)

"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2010-1-20 15:57:00 | 显示全部楼层

说白了就是带一组seed的随机函数

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-10-1 21:30 , Processed in 0.165256 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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