博客
关于我
笔试题:找亲戚(Python列表全排列,找能被7整除的数)
阅读量:380 次
发布时间: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/

你可能感兴趣的文章
oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
查看>>
oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
查看>>
oracle--用户,权限,角色的管理
查看>>
Oracle-定时任务-JOB
查看>>
oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
查看>>
oracle00205报错,Oracle控制文件损坏报错场景
查看>>
Oracle10g EM乱码之快速解决
查看>>
Oracle10g下载地址--多平台下的32位和64位
查看>>
Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
查看>>
oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
查看>>
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>
Oracle——08PL/SQL简介,基本程序结构和语句
查看>>
Oracle——distinct的用法
查看>>
Oracle、MySQL、SQL Server架构大对比
查看>>
oracle下的OVER(PARTITION BY)函数介绍
查看>>
Oracle中DATE数据相减问题
查看>>
Oracle中merge into的使用
查看>>