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

来源:互联网 发布:access数据库怎么打开 编辑:程序博客网 时间:2024/06/08 17:31

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    endendgenerateStr(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

阅读全文
0 0