鱼C论坛

 找回密码
 立即注册
查看: 7194|回复: 11

[技术交流] Python: 每日一题 63

[复制链接]
发表于 2017-7-27 21:21:35 | 显示全部楼层
写完看看前面,感觉自己怎么写得这么长··· ···
另外,真是佩服jerry大神,每次都能找着不一样的思路

碰到偶数位的数字就拆一半,把全排列过一遍
  1. # 可以将排除范围加快,遇到奇数位直接 *10
  2. def find_v_num(n):
  3.     result = []
  4.     i = 1260
  5.     while i <= n:
  6.         length = len(str(i))
  7.         if length %2:
  8.             i*=10
  9.         else:
  10.             for j in set(itertools.permutations(str(i))):
  11.                 if int("".join(j[:length//2]))*int("".join(j[length//2:])) == i:
  12.                     result.append(i)
  13.                     break
  14.             i += 1
  15.     return result
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-9-24 06:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表