じ☆ve冰风 发表于 2024-4-20 02:17:41

Array#shuffle! #shuffle #samples (优化)

RUBY 代码
classArray
def to_int
    self.object_id
end

CallWndProc = Win32API.new('user32.dll', 'CallWindowProc', 'PLLLL', 'L')

CodeSeed = [85,137,229,139,77,8,3,77,12,187,1,0,0,0,139,69,16,247,227,
    3,69,20,137,195,193,232,16,37,255,127,0,0,226,236,137,216,201,
    194,16,0].pack('C*')
@@seed = CallWndProc.call(CodeSeed, rand(41), 10, 214013, 2531011)

CodeShuffle = [85,137,229,139,93,8,139,76,27,8,131,249,1,118,55,139,116,27,
    16,73,141,60,142,139,93,12,139,69,16,247,227,3,69,20,137,195,193,232,16,
    37,255,127,0,0,49,210,65,247,241,73,193,226,2,1,242,255,50,255,55,143,2,
    143,7,131,239,4,226,214,137,216,201,194,16,0].pack('C*')

def shuffle!
    @@seed = CallWndProc.call(CodeShuffle, self, @@seed, 214013, 2531011)
    self
end

def shuffle
    (self + []).shuffle!
end

def sample
    self
end

CodeSamples = [85,137,229,139,69,8,139,92,0,8,139,68,0,16,137,69,8,141,116,
    152,252,139,69,12,139,76,0,8,81,139,68,0,16,141,124,136,252,184,253,67,3,
    0,247,101,20,5,160,51,130,1,137,69,20,193,232,16,37,255,127,0,0,49,210,
    247,243,75,193,226,2,3,85,8,255,50,255,54,143,2,143,6,137,23,131,239,4,
    131,238,4,226,203,89,131,198,4,139,6,131,199,4,139,23,137,7,255,50,255,
    54,143,2,143,6,226,234,139,69,20,201,194,16,0].pack('C*')

def samples(n)
    len = self.size
    returnselfif n < 2
    n = len if n > len
    returnself.shuffleif n == len
    result = Array.new(n)
    @@seed = CallWndProc.call(CodeSamples, self, result, 0, @@seed)      
    result
end
end


\s又是一年……,想起也在论坛发帖问过Array#sample\s

使用 Fisher-Yates 算法(几十年前的……,也是目前网上搜索最常见的洗牌算法)
随机则是参照C语言的rand()函数写的,使用该方法的数组大小不能超过0x7FFF

Array#shuffle!=> array_obj
Array#shuffle   => array_obj
Array#sample=> array_element_obj
Array#samples => array_obj

该帖方法效率基本为RUBY的同名或类似方法的十分之一 (RMVA测试)
由于是调用win32api的CallWidnowProc实现(最简单的code测试 8.5-8.6W次/秒……),较小运算量比不过ruby方法直接执行,运算量大的情况RMXP基本用不到……

优化:
①参数的改变,看起来更直接( 使用obj;原来obj.object_id。参数实质没变,效率我是感觉没差)
②优化了Array#samples,原先并没有用好result的内存……


关于效率测试,具体次数与电脑性能相关(my_**方法为该帖的方法)

RUBY 代码
# 非代码
=begin
rmva测试
【(0...10).to_a】
Array#suffle! :                         148031次/秒
Array#suffle :                        121141次/秒
Array#my_suffle! :                     68741次/秒
Array#my_suffle :                        60609次/秒
Array#sample(5) :                     131731次/秒
Array#my_samples(5) :                  55161次/秒
Array#sample(100) :                     126950次/秒
Array#my_samples(100) :                  56554次/秒
Array#sample(200) :                     126669次/秒
Array#my_samples(200) :                  56390次/秒

【(0...100).to_a】
Array#suffle! :                        70314次/秒
Array#suffle :                           60290次/秒
Array#my_suffle! :                     59772次/秒
Array#my_suffle :                        51764次/秒
Array#sample(5) :                     131434次/秒
Array#my_samples(5) :                  55044次/秒
Array#sample(100) :                      67510次/秒
Array#my_samples(100) :                  49509次/秒
Array#sample(200) :                      66997次/秒
Array#my_samples(200) :                  49541次/秒

【(0...500).to_a】
Array#suffle! :                        20981次/秒
Array#suffle :                           19097次/秒
Array#my_suffle! :                     38931次/秒
Array#my_suffle :                        32487次/秒
Array#sample(5) :                     131307次/秒
Array#my_samples(5) :                  54454次/秒
Array#sample(100) :                      57960次/秒
Array#my_samples(100) :                  45561次/秒
Array#sample(200) :                      41348次/秒
Array#my_samples(200) :                  38972次/秒

【(0...1000).to_a】
Array#suffle! :                        11331次/秒
Array#suffle :                           10317次/秒
Array#my_suffle! :                     27282次/秒
Array#my_suffle :                        22167次/秒
Array#sample(5) :                     130697次/秒
Array#my_samples(5) :                  55175次/秒
Array#sample(100) :                      49234次/秒
Array#my_samples(100) :                  45636次/秒
Array#sample(200) :                      36858次/秒
Array#my_samples(200) :                  39417次/秒

=end




             本帖来自P1论坛作者RPGzh500223,因Project1站服务器在国外有时候访问缓慢不方便作者交流学习,经联系P1站长fux2同意署名转载一起分享游戏制作经验,共同为国内独立游戏作者共同创造良好交流环境,原文地址:https://rpg.blue/forum.php?mod=viewthread&tid=488426若有侵权,发帖作者可联系底部站长QQ在线咨询功能删除,谢谢。
页: [1]
查看完整版本: Array#shuffle! #shuffle #samples (优化)