把1-9这9个数字按从小到大的顺序排列 ,中间添上“+”和"-","",可以计算的结果等于100的程序

Talk is cheap,show me the code~

穷举法

计算次数 3^8 = 6561,输出等于100的结果

arr = {1,2,3,4,5,6,7,8,9}
flag = {"+","-",""}
function generateStr(arr,str,index) 
    if index > #arr then
        if loadstring("return " .. str )() == 100 then
            print(str .. "=100")
        end     
    else
        for i = 1, #flag do 
             generateStr(arr,str .. flag[i] ..arr[index],index + 1) 
        end
    end
end

generateStr(arr,arr[1],2)

1+2+3-4+5+6+78+9=100
1+2+34-5+67-8+9=100
1+23-4+5+6+78-9=100
1+23-4+56+7+8+9=100
12+3+4+5-6-7+89=100
12+3-4+5+67+8+9=100
12-3-4+5-6+7+89=100
123+4-5+67-89=100
123+45-67+8-9=100
123-4-5-6-7+8-9=100
123-45-67+89=100

你可能感兴趣的:(lua,穷举法)