11.给你一个正整数列表 L, 如 L=[2,8,3,50], 输出L内全部数字的乘积末尾0的个数,

如例子L的结果为2.(提示:不要直接相乘,数字非常多,可能溢出)

Answer:
n_2 = 0
n_5 = 0
for tmp in L:
while tmp % 2 == 0:
n_2 += 1
tmp /= 2
while tmp % 5 == 0:
n_5 += 1
tmp /= 5
print min(n_2,n_5)

12.给你一个正整数列表 L, 如 L=[2,8,3,50], 推断列表内全部数字乘积的最后一个非零数字的奇偶性,

奇数输出1,偶数输出0. 如例子输出应为0

Answer:
result = reduce(lambda a,b:a*b, L)
no_zero = int(str(result).replace('0', ''))
print(no_zero & 1)

13.光棍们对1总是那么敏感,因此每年的11.11被戏称为光棍节。

鄙人光棍几十载,光棍自有光棍的快乐。

让我们勇敢面对光棍的身份吧,

如今就证明自己:给你一个整数a。数出a在二进制表示下1的个数。并输出。

a % 2 == 1
Answer:
print bin(a).count(“1")

14.输出Python之禅

注意:输出python之禅的源代码就可以,不用转换为英文。(小小的提示:print this.s)

Answer:
import this
print this.s

15.给定一个字符串a, 将a中的大写字母 转换成小写,其他字符不变,并输出。

Answer:
print a.lower()

16.银行在打印票据的时候。经常须要将阿拉伯数字表示的人民币金额转换为大写表示。如今请你来完毕这样一个程序。

在中文大写方式中。0到10以及100、1000、10000被依次表示为:

零壹贰叁肆伍陆柒捌玖拾佰仟万

下面的例子示范了阿拉伯数字到人民币大写的转换规则:

1 壹圆

11 壹拾壹圆

111 壹佰壹拾壹圆

101 壹佰零壹圆

-1000 负壹仟圆

1234567 壹佰贰拾叁万肆仟伍佰陆拾柒圆

如今给你一个整数a(|a|<100000000), 打印出人民币大写表示.

注意:因为中文乱码问题,输出时请先decode(“utf8”),比如你要输出ans = “零圆”, print ans.decode(“utf8”).

Answer:
m=['零','壹','贰','叁','肆','伍','陆','柒','捌','玖']
n=['','拾','佰','仟','圆','万']
b=str(abs(a))
l=len(b)
if a<0:
c='负'
else:
c='' def num(ln):
c=''
l=len(ln)
i=0
if l==1 and ln[0]=='0':
c+=m[0]
return c
if l==4 and ln=='0000':
c+=m[0]
return c
while i<l:
while i<l and int(ln[i])==0:
i+=1
if i<l and int(ln[i])!=0:
c+=m[0]
break
if i==l: break
c+=m[int(ln[i])]
c+=n[l-i-1]
i+=1
return c
if l<=4:
c=c+num(b)+n[4]
else:
c=c+num(b[:l-4])+n[5]+num(b[l-4:])+n[4]
print c.decode("utf8")

17 . 给你两个正整数a,b, 输出它们公约数的个数。

Answer:
print len(set([i for i in range(2,max(a,b)) if (a%i == 0 and b%i==0)])) + 1

18 . 我们经常遇到的问题是给你两个数。要你求最大公约数和最小公倍数。

今天我们反其道而行之,给你两个数a和b。计算出它们各自是哪两个数的最大公约数和最小公倍数。

输出这两个数,小的在前,大的在后,以空格隔开。若有多组解,输出它们之和最小的那组。

注:所给数据都有解,不用考虑无解的情况。

Answer:

c=b/a
l=[]
for i in range(c):
if c%(i+1)==0:
l.append(i+1)
print str(l[len(l)/2-1]*a)+" "+str(l[len(l)/2]*a)

19 . 抓不住爱情的我

总是眼睁睁看它溜走



如今来练习一下发现爱的能力,给你一个字符串a,假设当中包括”LOVE”(love不区分大写和小写)则输出LOVE,否则输出SINGLE。

Answer:
print 'LOVE' if 'love' in a.lower() else 'SINGLE'

20 . 给你个小写英文字符串a和一个非负数b(0<=b<26), 将a中的每一个小写字符替换成字母表中比它大b的字母。

这里将字母表的z和a相连,假设超过了z就回到了a。比如a=”cagy”,b=3, 则输出 fdjb

Answer:
s=''
for i in a:
if ord(i)>=97 and ord(i)<=122:
i=chr(97+(ord(i)+b-97)%26)
s+=i
print s

Mac 學習系列之Python Challenge 11-20的更多相关文章

  1. [Python學習筆記] 使用xlwings 插入註解 (forked 版本)

    到今天為止 xlwings 還沒有插入註解的功能 去原始開發者的 Github Pull Requests 他說之前有人有建議要加入這個功能 但他還沒更新~ 如果需要使用 Python 來插入註解的話 ...

  2. python 學習深淺拷貝、集合、、作用域、函數

    python 學習深淺拷貝.集合..作用域.函數 2020開年新冠肺炎流行大部分人員.工廠.單位無法復工生產,人員隔離每天外出都要戴口罩,在家隔離期間悶壞了感覺把半年的口糧都幹掉了,嚴重考察大家的資本 ...

  3. Linux网络设备驱动架構學習(三)

    Linux网络设备驱动架構學習(三) 接下來會從以下幾個方面介紹網絡設備驅動的編寫流程: 1.網絡設備的註冊與註銷 2.網絡設備的初始化 3.網絡設備的打開與釋放 4.網絡數據發送流程 5.網絡數據接 ...

  4. 學習 DT device tree 以 ST 的開發板 STM32F429i-disc1 為例

    目標 因為對 device tree 不是很熟悉, 所以就將 device tree, 設為學習目標. 啟動 注意, 這篇隨筆的解說都放在最下面,會標 Explanation_XX,只要搜尋 Expl ...

  5. 機器學習基石(Machine Learning Foundations) 机器学习基石 课后习题链接汇总

    大家好,我是Mac Jiang,非常高兴您能在百忙之中阅读我的博客!这个专题我主要讲的是Coursera-台湾大学-機器學習基石(Machine Learning Foundations)的课后习题解 ...

  6. 機器學習基石 (Machine Learning Foundations) 作业1 Q15-17的C++实现

    大家好,我是Mac Jiang.今天和大家分享Coursera-台湾大学-機器學習基石 (Machine Learning Foundations) -作业1的Q15-17题的C++实现. 这部分作业 ...

  7. The Python Challenge 谜题全解(持续更新)

    Python Challenge(0-2) The Python Challengehttp://www.pythonchallenge.com/ 是个很有意思的网站,可以磨练使用python的技巧, ...

  8. Linux网络设备驱动架構學習(二)

    Linux网络设备驱动架構學習(二) 接下來會從以下幾個方面介紹網絡設備驅動的編寫流程: 1.網絡設備的註冊與註銷 2.網絡設備的初始化 3.網絡設備的打開與釋放 4.網絡數據發送流程 5.網絡數據接 ...

  9. 機器學習基石(Machine Learning Foundations) 机器学习基石 作业三 课后习题解答

    今天和大家分享coursera-NTU-機器學習基石(Machine Learning Foundations)-作业三的习题解答.笔者在做这些题目时遇到非常多困难,当我在网上寻找答案时却找不到,而林 ...

随机推荐

  1. CentOS中如何安装7ZIP

    7-zip以高压缩率著称,并且是一款免费开源的压缩软件.在常规的Linux发行版中,无法通过简单的yum命令来安装该软件.那么在CentOS中,如何安装7ZIP呢?有以下3种方法: 第一种,源码编译安 ...

  2. “Warning: Call-time pass-by-reference has been deprecated in”解决方法

    刚刚在调试一个PHP木马,显示错误信息为: Warning: Call-time pass-by-reference has been deprecated in E:\New-Hack520org\ ...

  3. Promise小结

    Promise是异步里面的一种解决方案,解决了回调嵌套的问题,es6将其进行了语言标准,同意了用法,提供了`promise`对象, promise对象有三种状态:pending(进行中) .Resol ...

  4. Nand Flash与Nor

    转:http://www.360doc.com/content/11/1215/15/1299815_172458274.shtml Flash经常在一些地方被提到,一直没认真去理解它们的区别,因此, ...

  5. 性能问题: SQL*Net message from client 等待时间太长

    今天我终于自己遇到了这个问题, PO form 打不开了, 看了下 trace 发现 SQL*Net message from client 等待时间太长. 但是这不可能是网络问题, 这个环境是在我电 ...

  6. jrat

    JRat the Java Runtime Analysis Toolkit What is it? The Java Runtime Analysis Toolkit is a low overhe ...

  7. dcmtk dcmmkdir 使用帮助

    例子: dcmmkdir --recurse  --input-directory C:\TEMP DICOM --output-file C:\TEMP\DCMDIR --recurse 递归 -- ...

  8. windows 服务器不能使用剪贴板解决办法

    您可以在系统资源中先结束rdpclip.exe进程,然后重新打开c:\windows\system32\rdpclip.exe即可

  9. Java中常用的6种排序算法详细分解

    排序算法很多地方都会用到,近期又重新看了一遍算法,并自己简单地实现了一遍,特此记录下来,为以后复习留点材料. 废话不多说,下面逐一看看经典的排序算法: 1. 选择排序 选择排序的基本思想是遍历数组的过 ...

  10. Android 自定义数字加减器

    该自定义View主要是实现一款效果不错的数字加减器的功能的,但是也可以自定义选择器的外观颜色等. 1.自定义View的布局(add_sub_view.xml) <?xml version=&qu ...