博客
关于我
笔试题:找亲戚(Python列表全排列,找能被7整除的数)
阅读量:373 次
发布时间:2019-03-05

本文共 696 字,大约阅读时间需要 2 分钟。

全排列并检查模7余数

为了解决数字列表中的全排列问题并寻找能被7整除的数,我们可以编写一个递归函数来实现这个目标。以下是详细的实现方法:

首先,我们从输入的数字列表开始,然后使用递归的方式生成所有可能的排列组合。每次递归调用中,我们交换当前位置的数字与前一个位置的数字,以达到全排列的目的。在递归结束后,我们将所有生成的排列结果保存在一个列表中。

接下来,我们对保存的排列结果进行遍历,逐一将每个排列转换为整数,并检查它是否能被7整除。如果能被7整除,则将结果计数器加一。

最终,我们将计数器的值作为最终结果返回。

以下是完整的实现代码:

def Method(arr, p, q):    if p == q:        s.append(list(arr))    else:        for i in range(p, q):            arr[i], arr[p] = arr[p], arr[i]            Method(arr, p + 1, q)            arr[i], arr[p] = arr[p], arr[i]s = []res = 0arr = list(input().strip().split())Method(arr, 0, len(arr))for pl in s:    temp = int(''.join(pl))    if temp % 7 == 0:        res += 1print(res)

这个方法通过递归实现了全排列的生成,并对每一个排列结果进行了检查,最后统计满足条件的数的数量。

转载地址:http://bjvg.baihongyu.com/

你可能感兴趣的文章
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—5.Pipeline和Handler二
查看>>
Netty源码—6.ByteBuf原理一
查看>>
Netty源码—6.ByteBuf原理二
查看>>
Netty源码—7.ByteBuf原理三
查看>>
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理一
查看>>
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
查看>>
Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
查看>>
Netty:原理架构解析
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
Network 灰鸽宝典【目录】
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
network小学习
查看>>