笛卡尔积的递归和非递归的实现

#coding=utf-8
"""
    descartes alg
    2016-09-01 20:07
"""

"""
    loop
"""

def getDis(list_item, list_item1):
    temp_list = list()
    for iitem in list_item:
        for iitem2 in list_item1:
            temp_l = str()
            temp_l += str(iitem) + "\t"
            temp_l += str(iitem2) + "\t"
            temp_list.append(temp_l)
    return temp_list

def getNDis(total_list):
    list_result = total_list[0]
    for i in range(1, len(total_list)):
        list_result = getDis(list_result, total_list[i])
    print "loop result leng {0}".format(len(list_result))
    for ii in list_result:
        print "{0}\n".format(ii)


"""
    recursion
"""

def recursion(double_list, result_list, layer, current_list):
    if layer < len(double_list) - 1:
        if len(double_list[layer]) == 0:
            recursion(double_list, result_list, layer + 1, current_list)
        else:
            """
                不断递归
            """
            for iitem in double_list[layer]:
                new_list = current_list[0:]
                new_list.append(iitem)
                recursion(double_list, result_list, layer + 1, new_list)
    elif layer == len(double_list) - 1:
        if len(double_list[layer]) == 0:
            result_list.append(current_list)
        else:
            """
                最后退出的条件
            """
            for iitem in double_list[layer]:
                new_list = current_list[0:]
                new_list.append(iitem)
                result_list.append(new_list)


def main():
    tot_items = list()

    tot_item = list()
    tot_item.append("king")
    tot_item.append("of")
    tot_item.append("the")
    tot_item.append("world")
    tot_items.append(tot_item)

    tot_item = list()
    tot_item.append("cs")
    tot_item.append("app")
    tot_items.append(tot_item)

    tot_item = list()
    tot_item.append("good")
    tot_item.append("cool")
    tot_item.append("dev")
    tot_items.append(tot_item)

    tot_item = list()
    tot_item.append("king")
    tot_item.append("of")
    tot_item.append("the")
    tot_items.append(tot_item)

    getNDis(tot_items)

    result_list = list()
    temp_list = list()
    recursion(tot_items, result_list, 0, temp_list)
    print "recursion result leng {0}".format(len(result_list))
    for i in result_list:
        print "{0}".format(i)
    return

if __name__ == '__main__':
    main()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值