最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

python求解水仙花数的方法

来源:懂视网 责编:小采 时间:2020-11-27 14:33:25
文档

python求解水仙花数的方法

python求解水仙花数的方法:本文实例讲述了python求解水仙花数的方法。分享给大家供大家参考。具体如下: 一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数。 #!/usr/bin/python def get_flower(n, ofile): D_pow=[pow
推荐度:
导读python求解水仙花数的方法:本文实例讲述了python求解水仙花数的方法。分享给大家供大家参考。具体如下: 一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数。 #!/usr/bin/python def get_flower(n, ofile): D_pow=[pow

本文实例讲述了python求解水仙花数的方法。分享给大家供大家参考。具体如下:

一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数。

#!/usr/bin/python
def get_flower(n, ofile):
 D_pow=[pow(i,n) for i in range(0,10)]
 V_min=1*pow(10,n-1)
 V_max=sum((9*pow(10,x) for x in range(0,n)))
 T_count=0
 print D_pow, V_max, V_min
 nums=[1]+[0]*(n-1)
 print 'Start:', nums
 idx=n-1
 tmp_l=[0]*10
 while True:
 nums[idx]+=1
 if nums[idx]<10:
 j=idx+1
 while j=V_min:
 T_count+=1
 #test if is flower
 #print 'do test:', ''.join(map(str,nums))
 k=0
 while k<10:
 tmp_l[k]=0
 k+=1
 N=0
 for k in nums:
 tmp_l[k]+=1
 N+=1
 while N>0:
 p=v%10
 if tmp_l[p]>0:
 tmp_l[p]-=1
 N-=1
 else:
 break
 v/=10
 if N==0:
 print >>ofile, 'hit', sum((D_pow[x] for x in nums))
 idx=n-1
 elif idx==0:
 print 'done'
 break
 else:
 idx-=1
 print 't_count', T_count
if __name__ == '__main__':
 with file('./f.txt', 'wb') as o:
 get_flower(21, o)
 #get_flower(3, o)

希望本文所述对大家的Python程序设计有所帮助。

文档

python求解水仙花数的方法

python求解水仙花数的方法:本文实例讲述了python求解水仙花数的方法。分享给大家供大家参考。具体如下: 一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数。 #!/usr/bin/python def get_flower(n, ofile): D_pow=[pow
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top