lua table操作、运算

第一次随机取1至9中的4个,第二次随机取剩下的5个中的3个,第三次再取与第二次不重复的4个,以此类推。求解答... 第一次随机取1至9中的4个,第二次随机取剩下的5个中的3个,第三次再取与第二次不重复的4个,以此类推。求解答 展开
 我来答
flameleo11
推荐于2016-05-08 · TA获得超过5343个赞
知道大有可为答主
回答量:1943
采纳率:50%
帮助的人:992万
展开全部

你是说 第三次 再取 和 第一次 不重复的 4个


----------------------------------------
-- func
----------------------------------------

function init_array(n, start)
    start = start or 1
    local arr = {}
    for i = start, n do
        arr[i] = i
    end
    return arr, #arr
end

-- 返回从数组随机抽取的集合
function get_array_randpick(arr, n)
    local a = {}
    for key, var in pairs(arr) do
        a[key] = var
    end

    local t = {}
    local max = #a
    for i = 1, n do
        local x = math.random(1, max)
        table.insert(t, a[x])
        a[x] = a[max]
        a[max] = nil
        max = max - 1
    end
    return t, a
end

--- 计算两个数组的差异
-- @return 数组1中与数组2不相同的元素, 相同的元素 
function get_array_diff(arr, arr_other)
    assert(type(arr) == "table" and type(arr_other) == "table")
    local ht_other = {}
    for i, unit in ipairs(arr_other) do
        ht_other[unit] = true
    end

    local t_diff = {}
    local t_same = {}
    
    for i, unit in ipairs(arr) do
        if ht_other[unit] then     
            table.insert(t_same, unit)
        else
            table.insert(t_diff, unit)
        end
    end
    return t_diff, t_same
end

function print_arr(arr, name)
    name = name or "aArray"
    print(name.." = {") 
    for i, var in ipairs(arr) do
        print(string.format("  [%d] = %s", i, tostring(var)))
    end
    print "}"
end

----------------------------------------
-- test
----------------------------------------

local curtime = os.time() 
math.randomseed(curtime)
math.random()

----------------------------------------
-- main
----------------------------------------

local function main()
    local arr_org, len = init_array(9)
    local arr_next = arr_org 
    local arr_last_pick = {}
    
    local loop_max_times = 1000
    
    for i = 1, loop_max_times do
        local arr_pick1, arr_other1 = get_array_randpick(arr_next, 4)
        arr_next = get_array_diff(arr_org, arr_pick1)
        local arr_pick2, arr_other2 = get_array_randpick(arr_next, 3)
        
        if i < 10 then
            print_arr(arr_pick1, string.format("loop[%d].pick1 = ", i))
            print_arr(arr_pick2, string.format("loop[%d].pick2 = ", i))
        end
        
        
        local _, t_same = get_array_diff(arr_pick1, arr_pick2)
        assert(#t_same == 0)
        local _, t_same = get_array_diff(arr_pick1, arr_last_pick)
        assert(#t_same == 0)
    
        arr_last_pick = arr_pick1
    end
    
    print("\nok")
end

main()


追问
不好意思,我表达有误。。其实是,第三次和第二次不重复,取了第二次之后,第一次取的放回table中。 谢谢这位大哥的耐心解答!
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式