飞道的博客

《Python 100例》练习,基于Python 3.5做了一遍

434人阅读  评论(0)

搜语法的时候无意间在这里发现了个python100题。

本着复习python的想法做了一下,过程中发现有些题不像是python的,网上一搜才知道这东西原名叫做《C语言程序设计100个经典例子》,果然好坑。

挑能做的做了一遍,有的需要思考一下;而有的题对于python而言,实现起来实在太简单了。

-------------------

2018.2.1 补充tm016,关于datetime使用计算时间差的方法。
2018.3.16 修改tm089
2018.8.13 补充tm051,关于交集、并集、差集的说明
2019.5.24 修改tm017
2019.5.29 补充tm008
2019.7.5 补充tm100,zip函数用法
2019.8.20 修改tm003,tm005,补充tm099
2020.5.22 补充tm099

 

 


  
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. '''
  4. 2018.1.30
  5. Python 练习100题
  6. http://www.runoob.com/python/python-100-examples.html
  7. '''
  8. '''
  9. 题目001:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
  10. '''
  11. def tm001():
  12. '''
  13. 【个人备注】:按题意直接写出来
  14. '''
  15. arr = []
  16. for i in range( 1, 5):
  17. for j in range( 1, 5):
  18. for k in range( 1, 5):
  19. num = 100*i+ 10*j+k
  20. if i!=j and j!=k and i!=k and num not in arr: # 互不相同且无重复数字的三位数
  21. arr.append(num)
  22. print(len(arr),arr)
  23. def tm001_1():
  24. '''
  25. 【个人备注】:其实python自带排列组合模块,可以直接调用。
  26. 也知道这个写法,只是函数记不住,还是百度一下才能写出来。
  27. 如果这是面试题,能写出后一种当然好,不能的话还是老老实实的按照上面的思路来吧。
  28. itertools的排列组合用法我整理在这里《用 itertools 实现 组合、排列、组合(放回)、笛卡尔积》
  29. https://blog.csdn.net/watfe/article/details/80108774
  30. '''
  31. import itertools
  32. temp_arr = list(itertools.permutations([ 1, 2, 3, 4], 3)) # 排列 # A_4^3 = (4)!/(4-3)! = (4*3*2*1)/1 = 24
  33. arr = [ 100*t[ 0]+ 10*t[ 1]+t[ 2] for t in temp_arr]
  34. print(len(arr),arr)
  35. '''
  36. 题目002:企业发放的奖金根据利润(I)的多少来提成:
  37. 低于或等于10万元时,奖金可提10%;
  38. 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
  39. 20万到40万之间时,高于20万元的部分,可提成5%;
  40. 40万到60万之间时高于40万元的部分,可提成3%;
  41. 60万到100万之间时,高于60万元的部分,可提成1.5%;
  42. 高于100万元时,超过100万元的部分按1%提成。
  43. 从键盘输入当月利润I,求应发放奖金总数?
  44. '''
  45. def tm002():
  46. '''
  47. 程序分析:请利用数轴来分界,定位。
  48. 【个人备注】:这种处理数轴问题的写法,值得参考。比elif的写法,简洁方便的多。
  49. '''
  50. money = int(input( '净利润:'))
  51. arr = [ 1000000, 600000, 400000, 200000, 100000, 0]
  52. rat = [ 0.01, 0.015, 0.03, 0.05, 0.075, 0.1]
  53. bonus = 0
  54. for i in range(len(arr)):
  55. if money>arr[i]: # 对于处于区间的部分
  56. bonus+=(money-arr[i])*rat[i] # 计算并累加奖励
  57. money=arr[i] # 剩余部分
  58. print(bonus)
  59. '''
  60. 题目003:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
  61. '''
  62. def tm003():
  63. '''
  64. 【个人备注】:网站上是求了一下方程,没细看。
  65. python又不是没有开方函数,直接按字面意思解了。
  66. 2019-8-20 感谢Xueyang_Liu指出取值区间问题,进行修改。满足题意的数值不止一个两个。
  67. 考虑到取值区间,根据题意:
  68. 一个整数(m)加上100后是一个完全平方数 => m+100>=0,所以m>=-100,m取值下限为-100;
  69. 两个完全平方数的差是168,由于y=x**2这样的二次函数的图象是开口向上的抛物线,函数在x>0区间内单调递增,其导数可知两个相邻值y2-y1差值会越来越大 => (x+1)**2-x**2<=168,得x<=83.5。由于m=x**2-100,所以大约是m<7000的样子。
  70. 这样整数m的取值范围可以限定为[-100,7000]
  71. '''
  72. import math
  73. for i in range( -100, 7000):
  74. m = math.sqrt(i+ 100)
  75. n = math.sqrt(i+ 100+ 168)
  76. if m% 1== 0 and n% 1== 0:
  77. print(i)
  78. '''
  79. 最终会得到4个满足条件的整数:
  80. -99
  81. 21
  82. 261
  83. 1581
  84. '''
  85. def tm003_1():
  86. '''
  87. 如果不想使用开方函数,也可以使用Xueyang_Liu的方法也行。根据之前的推论x<=83.5,所以实际取值范围可以写成x<84。
  88. '''
  89. arr=[]
  90. result=[]
  91. for i in range( 84):
  92. arr+=[i** 2]
  93. for elem in arr:
  94. if elem+ 168 in arr:
  95. result+=[elem -100]
  96. return result
  97. '''
  98. 题目004:输入某年某月某日,判断这一天是这一年的第几天?
  99. '''
  100. def tm004():
  101. '''
  102. 【个人备注】:知道python有时间元组这一概念,这道题完全不需要计算。
  103. 时间元组包含九个属性
  104. tm_year 年
  105. tm_mon 月(1~12)
  106. tm_mday 日(1~31)
  107. tm_hour 时(0~23)
  108. tm_min 分(0~59)
  109. tm_sec 秒(0~61, 60或61是闰秒)
  110. tm_wday 星期(0~6, 0是周一)
  111. tm_yday 第几天(1~366, 366是闰年)
  112. tm_isdst 夏令时(1夏令时、0非夏令时、-1代表未知。平时写代码基本用不到。夏时令是指部分国家地区,夏季人为将时间调快一小时,早睡早起,以便充分利用夏日光照,节约用电。中国从1992年起就没有再执行过这个了)
  113. '''
  114. import time
  115. date = input( '输入时间(例如2018-01-23):')
  116. st = time.strptime(date, '%Y-%m-%d') # 时间文本转化成时间元祖
  117. num = st.tm_yday
  118. print(num)
  119. '''
  120. 题目005:输入三个整数x,y,z,请把这三个数由小到大输出。
  121. '''
  122. def tm005():
  123. print( '输入三个整数')
  124. x = int(input( '输入第1个整数:'))
  125. y = int(input( '输入第2个整数:'))
  126. z = int(input( '输入第3个整数:'))
  127. l = [x,y,z]
  128. arr = sorted(l) # 你也可以使用list.sort()方法来排序,此时list本身将被修改
  129. print(arr)
  130. '''
  131. 题目006:斐波那契数列。
  132. '''
  133. def tm006():
  134. '''
  135. 程序分析:斐波那契数列,又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
  136. 【个人备注】:很多种解法,我是按照分割的方式,每次取列表后两项,然后相加。
  137. '''
  138. l = [ 0, 1]
  139. for i in range( 10):
  140. arr = l[ -2:]
  141. l.append(arr[ 0]+arr[ 1])
  142. print(l)
  143. '''
  144. 题目007:将一个列表的数据复制到另一个列表中。
  145. '''
  146. def tm007():
  147. '''
  148. 【个人备注】:如果系统的看过python教程之类的应该都知道。
  149. Python里面一切都是对象,list的复制需要用[:]的方式。
  150. 至于b=a只是相当于给a取了个别名而已,指向的是同一个列表,并没有实现复制。
  151. '''
  152. a = [ 1, 2, 3]
  153. b = a[:]
  154. '''题外话'''
  155. a[ 0]= 0
  156. print(id(a),id(b)) # 可以看到a,b的内存不一致,是复制
  157. print(a,b) # 修改a,b不变
  158. a = [ 1, 2, 3]
  159. b = a
  160. a[ 0]= 0
  161. print(id(a),id(b)) # 如果去掉[:],可以看到a,b的内存一致,并没有复制,指向的是同一个列表
  162. print(a,b) # 修改a,b也变
  163. '''
  164. 题目008:题目:输出 9*9 乘法口诀表。
  165. '''
  166. def tm008():
  167. '''
  168. 【个人备注】:已经忘了,百度了才想起来口诀表具体长什么样。
  169. 注意 %-7s 和 end='' 的用法,其他没什么。
  170. '''
  171. for i in range( 1, 10):
  172. for j in range( 1, 10):
  173. if j<=i:
  174. string = '%d*%d=%d'%(j,i,j*i)
  175. print( '%-7s'%string,end= '')
  176. print( '')
  177. def tm008_1():
  178. '''
  179. csdn用户isgoto用format方法生成字符串,也可以参考。
  180. 用循环到i+1的方法,比上面还能少写一行。
  181. '''
  182. for i in range( 1, 10):
  183. for j in range( 1, i + 1):
  184. print( "{0} * {1} = {2}".format(i, j, i * j),end= "\t")
  185. print()
  186. '''
  187. 题目009:暂停一秒输出。
  188. '''
  189. def tm009():
  190. '''
  191. 【个人备注】:time.sleep(),用过的都知道。
  192. '''
  193. import time
  194. a = time.time()
  195. time.sleep( 1)
  196. b = time.time()
  197. print(b-a)
  198. '''
  199. 题目010:暂停一秒输出,并格式化当前时间。
  200. '''
  201. def tm010():
  202. '''
  203. 【个人备注】:时间格式化用过几次,用过就忘。关于时间处理的更多内容可以看tm016。
  204. '''
  205. import time
  206. a = time.strftime( '%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.localtime()时间戳转化成时间元祖
  207. print(a)
  208. time.sleep( 1)
  209. b = time.strftime( '%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.strftime()时间元祖转化成时间文本
  210. print(b)
  211. '''
  212. 题目011:古典问题:
  213. 有一对兔子,
  214. 从出生后第3个月起每个月都生一对兔子,
  215. 小兔子长到第三个月后每个月又生一对兔子。
  216. 假如兔子都不死。
  217. 问每个月的兔子总数为多少?
  218. '''
  219. def tm011():
  220. '''
  221. 其实这道题就是斐波那契数列的由来。
  222. 【个人备注】:理清思路是关键,理解成满两个月后,每月都能生兔子,就好办了。
  223. '''
  224. m1= 1 # 满月
  225. m2= 0 # 满俩月(下个月生兔子)
  226. mm= 0 # 可以月月生兔子了
  227. for i in range( 1, 10):
  228. # 过了1个月后
  229. mm = mm+m2 # 加入新增成年的兔子
  230. m2 = m1 # 满月的变成满俩月
  231. m1 = mm # 这个月新出生兔子
  232. print(i,mm+m1+m2) # 每个月有多少对兔子
  233. '''
  234. 题目012:判断101-200之间有多少个素数,并输出所有素数。
  235. '''
  236. def tm012():
  237. '''
  238. 【个人备注】:按照素数不能被之前的素数整除,取200以内所有素数,然后取出101-200之间的部分。
  239. '''
  240. arr = [ 2, 3]
  241. # 取200以内所有素数
  242. for i in range( 4, 201):
  243. for j in arr:
  244. if i%j== 0:
  245. break
  246. # else: # 这是一开始我自己的写法,后来发现for可以直接接else子语句
  247. # if j==arr[-1]:
  248. # arr.append(i)
  249. else: # 迭代的对象成功迭代完,位于else的子句将执行;而如果在for循环中含有break时则直接终止循环,并不会执行else子句。
  250. arr.append(i)
  251. # 取出100-200之间部分
  252. for i in range(len(arr)):
  253. if arr[i]> 100:
  254. l = arr[i:]
  255. print(len(l),l)
  256. break
  257. '''
  258. 题目013:打印出所有的"水仙花数",
  259. 所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
  260. 例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
  261. '''
  262. def tm013():
  263. '''
  264. 【个人备注】: // 取整,% 求余,**3 三次方。知道取整求余写法的就没问题。
  265. '''
  266. for i in range( 100, 1000):
  267. b = i// 100 # 百位
  268. s = i% 100// 10 # 十位
  269. g = i% 10 # 个位
  270. if b** 3+s** 3+g** 3==i:
  271. print(i)
  272. '''
  273. 题目014:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
  274. '''
  275. def tm014():
  276. '''
  277. 【个人备注】:拆到拆不动为止,类似012题。
  278. '''
  279. import math
  280. num = int(input( '输入一个整数:'))
  281. arr = []
  282. while num> 1:
  283. for i in range( 2,int(math.sqrt(num))+ 1): # 因为题目是一个没写范围正整数,开方可以有效减少该值过大时候的计算量
  284. if num%i== 0:
  285. arr.append(i)
  286. num = num//i
  287. break
  288. else:
  289. arr.append(num)
  290. break
  291. print(arr)
  292. '''
  293. 题目015:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
  294. '''
  295. def tm015():
  296. '''
  297. 【个人备注】:if-else基本用法,没啥说的。
  298. '''
  299. score = float(input( '输入一个成绩:'))
  300. if score>= 90:
  301. print( 'A')
  302. elif score>= 60:
  303. print( 'B')
  304. else:
  305. print( 'C')
  306. '''
  307. 题目016:输出指定格式的日期。
  308. '''
  309. def tm016():
  310. '''
  311. 【个人备注】:用的不多经常忘,整理了一下参考答案和一些转换
  312. 2019-5-29 以下日期时间代码仅供参考。
  313. 我将常用的日期时间方法,整理到了我的另一篇博客中
  314. 《Python3 日期文本互转,时间戳,时间差 以及 时区变换》
  315. https://blog.csdn.net/watfe/article/details/84943732
  316. '''
  317. import time
  318. print(time.time()) # 时间戳 1498539133.655
  319. print(time.localtime()) # 时间元祖 tm_year=2017, tm_mon=6, tm_mday=27, tm_hour=12, tm_min=53, tm_sec=16, tm_wday=1, tm_yday=178, tm_isdst=0
  320. print(time.asctime()) # 时间的一种可读文本形式 'Tue Jun 27 12:53:50 2017'
  321. print(time.strftime( '%Y-%m-%d %H:%M:%S',time.localtime())) # 按指定文本格式输出时间 '2017-06-27 13:00:57'
  322. st = time.localtime(time.time()) # 时间戳 转化成 时间元祖
  323. st = time.strptime( '2018/1/23', '%Y/%m/%d') # 时间文本 转化成 时间元祖
  324. date = time.strftime( '%Y-%m-%d',st) # 时间元祖 转化成 时间文本 '%Y-%m-%d %H:%M:%S'
  325. print(date) # 前面两条函数配合着用,相当于将时间文本重新格式化。
  326. '''
  327. 题目017:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
  328. '''
  329. def tm017():
  330. '''
  331. 【个人备注】:本来想写成这种格式来着
  332. import string
  333. if c in string.ascii_letters: # abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ
  334. if c == ' ': # 空格
  335. if c in string.digits: # 0123456789
  336. 看了参考答案才知道有现成的函数可以用。
  337. 其实随便哪种都行,甚至直接把一串字母粘上去看起来更直接。
  338. '''
  339. s = input( 'input a string:\n')
  340. letters,space,digit,others = 0, 0, 0, 0
  341. for c in s:
  342. if c.isalpha():
  343. letters += 1
  344. elif c.isspace():
  345. space += 1
  346. elif c.isdigit():
  347. digit += 1
  348. else:
  349. others += 1
  350. print( 'char = %d,space = %d,digit = %d,others = %d' % (letters,space,digit,others))
  351. '''
  352. 题目018:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。
  353. '''
  354. def tm018():
  355. '''
  356. 【个人备注】:答案给的解法很多种,但是我还是认为我写的方法最简单。
  357. 2+22+222+2222+22222
  358. 可以理解为:
  359. 20000 + 2*2000 + 3*200 + 4*20 + 5*2
  360. 也就是:
  361. 1*2*10^4 + 2*2*10^3 + 3*2*10^2 + 4*2*10^1 + 5*2*10^0
  362. 所以简单迭代就可以出结果
  363. '''
  364. a = 2
  365. t = 5
  366. num = 0
  367. for i in range( 1,t+ 1):
  368. num+=i*a*( 10**(t-i))
  369. print(num)
  370. '''
  371. 题目019:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。
  372. '''
  373. def tm019():
  374. '''
  375. 【个人备注】:题意看的不是太懂,于是百度了一下:完数就是除了自身之外的所有约数之和等于他本身。
  376. 第一个完全数是6,它有约数1、2、3、6,除去它本身6外,其余3个数相加,1+2+3=6。
  377. 第二个完全数是28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。
  378. 终于看懂了题意。
  379. 先求出所有约数,然后求和比一下是否相等就行了,没有难度
  380. '''
  381. for num in range( 1, 1000):
  382. arr = []
  383. for i in range( 1,num):
  384. if num%i== 0:
  385. arr.append(i)
  386. if sum(arr)==num:
  387. print(num,arr)
  388. '''
  389. 题目020:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?
  390. '''
  391. def tm020():
  392. '''
  393. 【个人备注】:很简单,没啥说的
  394. '''
  395. total = 0
  396. m = 100 # 第一次落地,经过了一百米
  397. total += m
  398. for i in range( 10 -1): # 之后9次弹起到落地
  399. m = m/ 2 # 弹起的高度
  400. total += 2*m # 弹起然后重新落地,一共经过的距离
  401. print(total)
  402. print(m/ 2)
  403. '''
  404. 题目021:猴子吃桃问题
  405. 猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
  406. 第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
  407. 以后每天早上都吃了前一天剩下的一半零一个。
  408. 到第10天早上想再吃时,见只剩下一个桃子了。
  409. 求第一天共摘了多少。
  410. '''
  411. def tm021():
  412. '''
  413. 【个人备注】:第十天num=1个,第九天必然是4个:4/2-1=1,也就是(num+1)*2=4。
  414. 做这种题,先用算数式列出来,然后用代码描述就行了。
  415. '''
  416. num = 1
  417. for i in range( 10 -1):
  418. num = (num+ 1)* 2
  419. print(num)
  420. '''
  421. 题目022:两个乒乓球队进行比赛,各出三人。
  422. 甲队为a,b,c三人,乙队为x,y,z三人。
  423. 已抽签决定比赛名单。有人向队员打听比赛的名单。
  424. a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
  425. '''
  426. def tm022():
  427. '''
  428. 【个人备注】:关键是将抽象化,将问题抽象成代码方式。
  429. 我的解题思路,是用排列组合函数,列出方案,然后排除。
  430. 而官方解答里面有一个纯粹的for循环加if的求解方式,
  431. 更抽象一些,用了一个很常用固定范式,直接拿来解题了。
  432. 稍微对其抽象的方法注释了一下。
  433. '''
  434. import itertools
  435. jia = [ 'a', 'b', 'c']
  436. yi = [ 'x', 'y', 'z']
  437. arr = list(itertools.permutations(yi, 3)) # 面对甲队a,b,c时,乙队所有排列 [('x', 'y', 'z'), ('x', 'z', 'y'), ('y', 'x', 'z'), ('y', 'z', 'x'), ('z', 'x', 'y'), ('z', 'y', 'x')]
  438. arr = [[jia[i]+a[i] for i in range( 3)] for a in arr] #将a,b,c写上,得到所有对阵组合 [['ax', 'by', 'cz'], ['ax', 'bz', 'cy'], ['ay', 'bx', 'cz'], ['ay', 'bz', 'cx'], ['az', 'bx', 'cy'], ['az', 'by', 'cx']]
  439. for i in arr:
  440. if 'ax' in i:
  441. pass
  442. elif 'cx' in i or 'cz' in i:
  443. pass
  444. else:
  445. print(i) # 得到 ['az', 'bx', 'cy']
  446. def tm022_1():
  447. for a in [ 'x', 'y', 'z']: # a在x,y,z中挑一个打
  448. for b in [ 'x', 'y', 'z']: # b在x,y,z中挑一个打
  449. for c in [ 'x', 'y', 'z']: # c在x,y,z中挑一个打 三层总计27种打法
  450. if a!=b and b!=c and c!=a: # a,b,c不能挑同一个人 缩减到6种打法
  451. if a!= 'x' and c!= 'x' and c!= 'z': # 依据题意不能ax,cx,cz 缩减到1种打法
  452. print( 'a'+a, 'b'+b, 'c'+c)
  453. '''
  454. 题目023:
  455. 打印出如下图案(菱形):
  456. *
  457. ***
  458. *****
  459. *******
  460. *****
  461. ***
  462. *
  463. '''
  464. def tm023():
  465. '''
  466. 【个人备注】:想到了绝对值,
  467. 然后将[0,1,2,3,4,5,6]变成了[3,2,1,0,1,2,3],也就是每行左边空格数。
  468. '''
  469. num = 7
  470. for i in range(num):
  471. blank = abs(num// 2-i)
  472. print( ' '*blank+ '*'*(num -2*blank)+ ' '*blank)
  473. '''
  474. 题目024:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。
  475. '''
  476. def tm024():
  477. '''
  478. 没啥好说的
  479. '''
  480. a,b,num = 2, 1, 0
  481. for i in range( 20):
  482. num+=a/b
  483. a=a+b
  484. b=a-b
  485. print(num)
  486. '''
  487. 题目025:求1+2!+3!+...+20!的和。
  488. '''
  489. def tm025():
  490. '''
  491. 【个人备注】:实现起来很简单。
  492. 下面官方的代码,比我写的更简洁。
  493. '''
  494. s,t= 0, 1
  495. for n in range( 1, 21):
  496. t*=n
  497. s+=t
  498. print(s)
  499. '''
  500. 题目026:利用递归方法求5!。
  501. '''
  502. def fac(x):
  503. if x> 1:
  504. return x*fac(x -1)
  505. else:
  506. return x
  507. def tm026():
  508. '''
  509. 【个人备注】:按题目要求,公式f(n)=n*f(n-1),递归调用求解。
  510. '''
  511. print(fac( 5))
  512. '''
  513. 题目027:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
  514. '''
  515. def output(s,l):
  516. if l== 0:
  517. return
  518. print (s[l -1])
  519. output(s,l -1)
  520. def tm027():
  521. '''
  522. 【个人备注】:直接从官网复制,不喜欢递归。
  523. '''
  524. s = input( 'Input a string:')
  525. l = len(s)
  526. output(s,l)
  527. '''
  528. 题目028:有5个人坐在一起,
  529. 问第五个人多少岁?他说比第4个人大两岁。
  530. 问第4个人,他说比第3个人大两岁。
  531. 问第3个人,又说比第2个人大两岁。
  532. 问第2个人,说比第1个人大两岁。
  533. 最后问第一个人,他说是10岁。
  534. 请问第五个人多大?
  535. '''
  536. def age(x):
  537. if x> 1:
  538. return 2+age(x -1)
  539. else:
  540. return 10
  541. def tm028():
  542. '''
  543. 【个人备注】:官网给的还是递归方法,因为不用递归的话就是个口算题。
  544. '''
  545. print(age( 5))
  546. '''
  547. 题目029:给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。
  548. '''
  549. def tm029():
  550. '''
  551. 【个人备注】:用Python,So Easy~
  552. list倒序可以用list.reverse();
  553. 字符串就只能用步长=-1的方式来倒序了。
  554. '''
  555. num = 12345
  556. s = str(num)
  557. print(len(s))
  558. print(s[:: -1])
  559. '''
  560. 题目030:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。
  561. '''
  562. def tm030():
  563. '''
  564. 【个人备注】:没啥可说的。
  565. '''
  566. num = 12321
  567. s = str(num)
  568. for i in range(len(s)// 2):
  569. if s[i]!=s[-i -1]:
  570. print( False)
  571. break
  572. else:
  573. print( True)
  574. '''
  575. 题目031:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。
  576. '''
  577. def tm031():
  578. '''
  579. 【个人备注】:按照题意要求实现了就行
  580. '''
  581. week = [ 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday', 'sunday']
  582. inp = ''
  583. while 1:
  584. arr = []
  585. inp = inp+input( '请输入一个字母:')
  586. for day in week: # 挑出满足输入的星期
  587. if inp==day[:len(inp)]:
  588. arr.append(day)
  589. if len(arr)== 1: # 只剩一个,说明唯一,可以输出结果
  590. print( '以%s开头的单词是:%s'%(inp,arr[ 0]))
  591. inp= ''
  592. elif len(arr)== 0: # 一个都没有说明输错了,需要重新输入
  593. print( '没有%s开头的单词'%inp)
  594. inp= ''
  595. '''
  596. 题目032:按相反的顺序输出列表的值。
  597. '''
  598. def tm032():
  599. '''
  600. 【个人备注】:之前已经做过了
  601. '''
  602. # 方法一
  603. a = [ 1, 2, 3, 4, 5]
  604. print(a[:: -1])
  605. # 方法二
  606. a = [ 1, 2, 3, 4, 5]
  607. a.reverse()
  608. print(a)
  609. # 方法三
  610. a = [ 1, 2, 3, 4, 5]
  611. a.sort(reverse= True)
  612. print(a)
  613. '''
  614. 题目033:按逗号分隔列表。
  615. '''
  616. def tm033():
  617. '''
  618. 【个人备注】:一开始没看懂题目想干啥,直接print(list)不就是逗号分隔么
  619. 实际上题目的意思是,合并列表项,以逗号为间隔
  620. '''
  621. a = [ '1', '2', '3', '4', '5']
  622. print( ','.join(a))
  623. '''
  624. 题目034:练习函数调用。
  625. '''
  626. def tm034():
  627. '''
  628. 【个人备注】:没头没尾的一个题,之前的递归实际上就是函数的调用了。不写了。
  629. '''
  630. pass
  631. '''
  632. 题目035:文本颜色设置。
  633. '''
  634. def tm035():
  635. '''
  636. 【个人备注】:感觉不像是python的题。
  637. '''
  638. pass
  639. '''
  640. 题目036:求100之内的素数。
  641. '''
  642. def tm036():
  643. '''
  644. 【个人备注】:素数就是质数
  645. '''
  646. arr = [ 2]
  647. for i in range( 3, 100):
  648. for j in arr:
  649. if i%j== 0:
  650. break
  651. else:
  652. arr.append(i)
  653. print(arr)
  654. '''
  655. 题目037:对10个数进行排序。
  656. '''
  657. def tm037():
  658. '''
  659. 【个人备注】:实际上考察的是排序。揣测了一下题意,写了两种解法
  660. '''
  661. # 方法1,python解法
  662. a = [ 1, 5, 7, 3, 2, 4, 9, 10, 6, 8]
  663. a.sort()
  664. print(a)
  665. # 方法2,常规解法
  666. a = [ 1, 5, 7, 3, 2, 4, 9, 10, 6, 8]
  667. b = [a[ 0]]
  668. for num in a[ 1:]:
  669. for i in range(len(b)):
  670. if num<b[i]:
  671. b.insert(i,num)
  672. break
  673. else:
  674. b.append(num)
  675. print(b)
  676. '''
  677. 题目038:求一个3*3矩阵主对角线元素之和。
  678. '''
  679. def tm038():
  680. '''
  681. 【个人备注】:思路比较简单,n*n的矩阵都可以用这个求解。
  682. '''
  683. a = [[ 1, 2, 3],[ 4, 5, 6],[ 7, 8, 9]]
  684. s = 0
  685. n = len(a)
  686. for i in range(n): # 左上到右下一条线
  687. s+=a[i][i]
  688. for i in range(n): # 右上到左下一条线
  689. s+=a[i][n-i -1]
  690. if n% 2== 1: # 如果是奇数,删掉重复计算的中间点
  691. s-=a[n// 2][n// 2]
  692. print(s)
  693. '''
  694. 题目039:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
  695. '''
  696. def tm039():
  697. '''
  698. 【个人备注】:037题中刚写过。
  699. 暂且不考虑各种奇奇怪怪的排序规律,假定规律就是从小到大的
  700. '''
  701. aaa = [ 1, 5, 8, 14, 28, 39, 60, 89, 134, 324, 612, 900]
  702. b = 555
  703. for a in aaa:
  704. if b<a:
  705. aaa.insert(aaa.index(a),b)
  706. break
  707. else:
  708. aaa.append(b)
  709. print(aaa)
  710. '''
  711. 题目040:将一个数组逆序输出。
  712. '''
  713. def tm040():
  714. '''
  715. 【个人备注】:就是032题,重复了。
  716. '''
  717. pass
  718. '''
  719. 题目041:模仿静态变量的用法。
  720. '''
  721. def tm041():
  722. '''
  723. 【个人备注】:不是很清楚什么意思,直接看了官网的解答。
  724. 如果是函数中的局部变量,每次调用函数都会初始化。
  725. 而类中的变量,创建类的时候初始化,每次执行类中的函数的时候,不会初始化类变量。
  726. 看起来是想说这么个意思。
  727. '''
  728. def varfunc():
  729. var = 0
  730. print( 'var = %d' % var)
  731. var += 1
  732. if __name__ == '__main__':
  733. for i in range( 3):
  734. varfunc()
  735. # StaticVar作为类的一个属性,相当于静态变量
  736. class Static:
  737. StaticVar = 5
  738. def varfunc(self):
  739. self.StaticVar += 1
  740. print(self.StaticVar)
  741. print(Static.StaticVar)
  742. a = Static()
  743. for i in range( 3):
  744. a.varfunc()
  745. '''
  746. 题目042:学习使用auto定义变量的用法。
  747. '''
  748. def tm042():
  749. '''
  750. 【个人备注】:同样没看懂题意,看了下官网答案
  751. 发现实际是想说变量作用域, python是有分局部变量、全局变量的等区分的。
  752. '''
  753. num = 2
  754. def autofunc():
  755. num = 1
  756. print( 'internal block num = %d'%num)
  757. num += 1
  758. for i in range( 3):
  759. print( 'The num = %d'%num)
  760. num += 1
  761. autofunc()
  762. '''
  763. 以上实例输出结果为:
  764. The num = 2
  765. internal block num = 1
  766. The num = 3
  767. internal block num = 1
  768. The num = 4
  769. internal block num = 1
  770. '''
  771. '''
  772. 题目043:模仿静态变量(static)另一案例。
  773. '''
  774. def tm043():
  775. '''
  776. 【个人备注】:官网的答案和041没啥区别,又来一遍
  777. '''
  778. '''
  779. 题目044:两个3*3的矩阵,实现其对应位置的数据相加,并返回一个新矩阵:
  780. X = [[12,7,3],
  781. [ 4,5,6],
  782. [ 7,8,9]]
  783. Y = [[5,8,1],
  784. [ 6,7,3],
  785. [ 4,5,9]]
  786. '''
  787. def tm044():
  788. '''
  789. 【个人备注】:自己写了一个,但是印象里python是有矩阵计算工具的。
  790. 官网就有人用该工具numpy写了一下,很简洁。
  791. '''
  792. x = [[ 12, 7, 3],[ 4, 5, 6],[ 7, 8, 9]]
  793. y = [[ 5, 8, 1],[ 6, 7, 3],[ 4, 5, 9]]
  794. z = x[:]
  795. for i in range( 3):
  796. for j in range( 3):
  797. z[i][j]=x[i][j]+y[i][j]
  798. print(z)
  799. def tm044_1():
  800. import numpy # pip install numpy 需要安装模块
  801. x = numpy.array([[ 12, 7, 3],[ 4, 5, 6],[ 7, 8, 9]])
  802. y = numpy.array([[ 5, 8, 1],[ 6, 7, 3],[ 4, 5, 9]])
  803. z = x+y
  804. print(z)
  805. '''
  806. 题目045:统计 1 到 100 之和。
  807. '''
  808. def tm045():
  809. '''
  810. 【个人备注】:简单,但官网有人写的更简单
  811. '''
  812. s = 0
  813. for i in range( 1, 101):
  814. s+=i
  815. print(s)
  816. # 更简洁的方法
  817. print(sum(range( 1, 101)))
  818. '''
  819. 题目046:求输入数字的平方,如果平方运算后小于 50 则退出。
  820. '''
  821. def tm046():
  822. '''
  823. 【个人备注】:简单
  824. '''
  825. while 1:
  826. x= input( '输入数字得到平方值:')
  827. print(x*x)
  828. if x*x< 50:
  829. break
  830. '''
  831. 题目047:两个变量值互换。
  832. '''
  833. def tm047():
  834. '''
  835. 【个人备注】:很简单
  836. '''
  837. a,b= 1, 2
  838. a,b=b,a
  839. print(a,b)
  840. '''
  841. 题目048:数字比较。
  842. '''
  843. def tm048():
  844. '''
  845. 【个人备注】:看了一眼官网答案,简单到懒得写。以下官网答案。
  846. '''
  847. i = 10
  848. j = 20
  849. if i > j:
  850. print( '%d 大于 %d' % (i,j))
  851. elif i == j:
  852. print( '%d 等于 %d' % (i,j))
  853. elif i < j:
  854. print( '%d 小于 %d' % (i,j))
  855. else:
  856. print( '未知')
  857. '''
  858. 题目049:使用lambda来创建匿名函数。
  859. '''
  860. def tm049():
  861. '''
  862. 【个人备注】:用的不多又忘了,看了一下网上的教程,整理了一下。
  863. '''
  864. #lambda函数也叫匿名函数,即,函数没有具体的名称。先来看一个最简单例子:
  865. def f(x):
  866. return x** 2
  867. print(f( 4))
  868. #Python中使用lambda的话,写成这样
  869. g = lambda x:x** 2
  870. print(g( 4))
  871. #lambda存在意义就是对简单函数的简洁表示。
  872. #lambda语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右边的返回值。
  873. #常搭配内置函数map、filter、reduce,都是应用于序列的内置函数。常见的序列包括list、tuple、str。
  874. #map(func, *iterables) --> map object
  875. #filter(function or None, iterable) --> filter object
  876. #reduce(function, sequence[, initial]) -> value
  877. foo = [ 2, 18, 9, 22, 17, 24, 8, 12, 27]
  878. print(list(map( lambda x: x * 2 + 10, foo))) # 映射 [14, 46, 28, 54, 44, 58, 26, 34, 64]
  879. print(list(filter( lambda x: x % 3 == 0, foo))) # 过滤 [18, 9, 24, 12, 27]
  880. from functools import reduce # 在Python 3里,reduce()函数已经被从全局名字空间里移除了,它现在被放置在fucntools模块里
  881. print(reduce( lambda x, y: x + y, foo)) # 累积 139
  882. '''
  883. 题目050:输出一个随机数。
  884. '''
  885. def tm050():
  886. '''
  887. 【个人备注】:之前学习随机的时候整理的东西,用到时候来找就行了
  888. '''
  889. import random
  890. # 随机数操作
  891. random.random() # 0.85415370477785668 # 随机一个[0,1)之间的浮点数
  892. random.uniform( 0, 100) # 18.7356606526 # 随机一个[0,100]之间的浮点数
  893. random.randrange( 0, 100, 2) # 44 # 随机一个[0,100)之间的偶数
  894. random.randint( 0, 100) # 22 # 随机一个[0,100]之间的整数
  895. # 随机字符操作
  896. seed = "1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+=-" # 任意字符串(作为随机字符种子库)
  897. random.choice(seed) # 'd' # 随机一个字符
  898. random.sample(seed, 3) # ['a', 'd', 'b'] # 随机多个字符(字符可重复)
  899. ''.join(random.sample(seed, 3)) # '^f^' # 随机指定长度字符串(字符可重复)
  900. # 随机列表操作
  901. random.shuffle(list) # 列表中的元素打乱
  902. '''
  903. 题目051~053、055:
  904. 学习使用按位与 &
  905. 学习使用按位或 |
  906. 学习使用按位异或 ^
  907. 学习使用按位取反 ~
  908. '''
  909. def tm051(): # tm052 # tm053 # tm055
  910. '''
  911. 【个人备注】:大概看了一下资料,按位操作可以通过bin()函数转换为二进制从而实现。
  912. 感觉二进制的计算如果不是学加密之类的基本用不上。
  913. 所以这一题,大概写了集合的用法,&、|在python中是集合set()才用的符号
  914. 两个列表求交集并集,通常也都是转换为集合,然后进行计算的。
  915. '''
  916. # 可迭代变量转换为集合形式
  917. x = set( 'runoob')
  918. y = set( 'google')
  919. print(x, y) # 重复的被删除 {'n', 'o', 'b', 'u', 'r'} {'o', 'g', 'e', 'l'}
  920. # 集合的交集、并集、差集
  921. print(x & y) # 交集 {'o'}
  922. print(x | y) # 并集 {'e', 'o', 'g', 'l', 'u', 'n', 'b', 'r'}
  923. print(x - y) # 差集 {'n', 'b', 'u', 'r'}
  924. # 当然也可以写成函数形式,不过确实没有上面符号好记。
  925. print(x.intersection(y))
  926. print(x.union(y))
  927. print(x.difference(y))
  928. '''
  929. 题目054:取一个整数a从右端开始的4-7位。
  930. '''
  931. def tm054():
  932. '''
  933. 【个人备注】:官网答案不对
  934. '''
  935. a = 123456789
  936. b = str(a)
  937. print(b[ -7: -3]) # 写的时候注意一下python切片是[-7:-4)左闭右开的,不包含[-4]的,所以要写成-3才能取到
  938. '''
  939. 题目056:画图,学用circle画圆形。
  940. 题目057:画图,学用line画直线。
  941. 题目058:画图,学用rectangle画方形。
  942. 题目059:画图,综合例子。
  943. 题目063:画椭圆。
  944. 题目064:利用ellipse 和 rectangle 画图。
  945. 题目065:一个最优美的图案。 
  946. 所有画图题pass 有爱的自己参照下面,将官网答案改成python3运行即可。
  947. '''
  948. def tm056(): # tm057、tm058、tm059、tm063、tm064、tm065、
  949. '''
  950. 【个人备注】:这个技能感觉用不上啊。
  951. 复制了官网Python2答案,调整一下放到python3上成功运行了。
  952. '''
  953. import tkinter
  954. canvas = tkinter.Canvas(width= 600, height= 500, bg= 'yellow')
  955. canvas.pack(expand= 'yes', fill= 'both')
  956. k = 1
  957. j = 1
  958. for i in range( 0, 26):
  959. canvas.create_oval( 300 - k, 250 - k, 300 + k, 250 + k, width= 1)
  960. k += j
  961. j += 0.6
  962. canvas.mainloop()
  963. '''
  964. 题目060:计算字符串长度。 
  965. '''
  966. def tm060():
  967. '''
  968. 【个人备注】:无
  969. '''
  970. a = 'aegweg'
  971. print(len(a))
  972. '''
  973. 题目061:打印出杨辉三角形(要求打印出10行如下图)。
  974. 1
  975. 1 1
  976. 1 2 1
  977. 1 3 3 1
  978. 1 4 6 4 1
  979. 1 5 10 10 5 1
  980. 1 6 15 20 15 6 1
  981. 1 7 21 35 35 21 7 1
  982. 1 8 28 56 70 56 28 8 1
  983. 1 9 36 84 126 126 84 36 9 1
  984. '''
  985. def tm061():
  986. '''
  987. 【个人备注】:感觉自己写的比官网简单好懂
  988. '''
  989. arr = [ 1]
  990. print( 1)
  991. while len(arr)< 10: # [1,1]
  992. a = [ 0]+arr # [0,1,1]
  993. b = arr+[ 0] # [1,1,0]
  994. arr = [a[i]+b[i] for i in range(len(a))] # [1,2,1]
  995. s = [str(i) for i in arr]
  996. print( ' '.join(s))
  997. '''
  998. 题目062:查找字符串。
  999. '''
  1000. def tm062():
  1001. s = 'abcde'
  1002. print(s.find( 'c'))
  1003. '''
  1004. 题目066:输入3个数a,b,c,按大小顺序输出。
  1005. '''
  1006. def tm066():
  1007. arr=[]
  1008. for i in range( 3):
  1009. a = input( '请输入数字:')
  1010. arr.append(int(a))
  1011. arr.sort(reverse= True)
  1012. print( '从大到小',arr)
  1013. '''
  1014. 题目067:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
  1015. '''
  1016. def tm067():
  1017. '''
  1018. 【个人备注】:感觉自己写的比官网简单好懂,直接用python思维写,确实很方便
  1019. '''
  1020. a = [ 6, 3, 10, 2, 5, 1, 4, 7, 9, 8]
  1021. i = a.index(max(a))
  1022. a[ 0],a[i] = a[i],a[ 0]
  1023. i = a.index(min(a))
  1024. a[ -1],a[i] = a[i],a[ -1]
  1025. print(a)
  1026. '''
  1027. 题目068:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
  1028. '''
  1029. def tm068():
  1030. a = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  1031. m = 3
  1032. b = a[-m:]+a[:-m]
  1033. print(b)
  1034. '''
  1035. 题目069:有n个人围成一圈,顺序排号。
  1036. 从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
  1037. '''
  1038. def tm069():
  1039. '''
  1040. 【个人备注】:python基础变量没有这种圈状循环的。
  1041. 最直接的方法是列表,点队尾再从头开始。
  1042. 缺点是列表删除中间项,后面的索引值都会变,需要计算。
  1043. 所以我换了种方法,
  1044. 把问题抽象成排队进门的问题
  1045. 完全不考虑索引问题。
  1046. '''
  1047. # 初始化
  1048. n = 34
  1049. arr = list(range( 1,n+ 1)) # 所有人门外站成一队【a】,进门后依旧按序站好【b】
  1050. count,a,b = 0,arr,[]
  1051. # 开始解题
  1052. while len(a+b)> 1: # 循环直到只剩1人
  1053. num,count=a.pop( 0),count+ 1 # 排队进门,每进一人【a.pop】,按一下计数器
  1054. if count% 3!= 0:b.append(num) # 进门后依旧按序站好【b.append】,计数器逢3淘汰。
  1055. if a==[]:a,b=b,[] # 如果门外没人了【a=[]】,所有人重新到门外站好【a=b】
  1056. print(a[ 0])
  1057. '''
  1058. 题目070:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。
  1059. '''
  1060. def tm070():
  1061. '''
  1062. 【个人备注】:简单
  1063. '''
  1064. def getlength(string):
  1065. return len(string)
  1066. if __name__ == '__main__':
  1067. x = 'abcde'
  1068. print(getlength(x))
  1069. '''
  1070. 题目071:编写input()和output()函数输入,输出5个学生的数据记录。
  1071. '''
  1072. def tm071():
  1073. '''
  1074. 【个人备注】:用字典类型随便写写
  1075. '''
  1076. def inp(data):
  1077. name = input( '输入学生姓名:')
  1078. score = input( '输入学生成绩:')
  1079. data[name]=score
  1080. print( '成功录入')
  1081. return data
  1082. def outp(data):
  1083. name = input( '输入学生姓名:')
  1084. print( '该学生的成绩是:',data.get(name))
  1085. return data
  1086. if __name__ == '__main__':
  1087. data = {}
  1088. while 1:
  1089. a = input( '输入/输出学生成绩(i/o):')
  1090. if a== 'i':
  1091. data = inp(data)
  1092. elif a== 'o':
  1093. data = outp(data)
  1094. else:
  1095. print( '输入值不对')
  1096. '''
  1097. 题目072:创建一个链表。
  1098. 题目073:反向输出一个链表。
  1099. '''
  1100. def tm072():
  1101. '''
  1102. 【个人备注】:已经几乎忘了链表了,网上搜了一下终于想起链表是什么来着。
  1103. 这种底层的东西,完全没必要用python去模拟
  1104. http://www.newsmth.net/nForum/#!article/Python/73818?p=10
  1105. '''
  1106. pass
  1107. '''
  1108. 题目074:列表排序及连接。
  1109. 题目079:字符串排序。(也是一样的)
  1110. '''
  1111. def tm074(): # tm079
  1112. '''
  1113. 【个人备注】:之前都用过
  1114. '''
  1115. a = [ 3, 2, 1]
  1116. b = [ 4, 5, 6]
  1117. a.sort()
  1118. print(a)
  1119. print(a+b)
  1120. '''
  1121. 题目075:放松一下,算一道简单的题目。
  1122. '''
  1123. def tm075():
  1124. '''
  1125. 【个人备注】:Σ( ° △ °|||)︴,不是我偷工减料,题目就是这个,后面太监了
  1126. '''
  1127. pass
  1128. '''
  1129. 题目076:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n
  1130. '''
  1131. def tm076():
  1132. '''
  1133. 【个人备注】:学了lambda想耍一下,结果发现官网写的比我还简洁!
  1134. '''
  1135. n = 17
  1136. fenmu = range( 2,n+ 1, 2) if n% 2== 0 else range( 1,n+ 1, 2)
  1137. s = sum(map( lambda x: 1/x,fenmu))
  1138. print(s)
  1139. # 官网参考答案
  1140. n = 17
  1141. ls = sum([ 1/i for i in range(n, 0, -2)])
  1142. print(ls)
  1143. '''
  1144. 题目077:循环输出列表
  1145. '''
  1146. def tm077():
  1147. '''
  1148. 【个人备注】:无需动脑
  1149. '''
  1150. l = [ 1, 2, 3, 4, 5]
  1151. for i in l:
  1152. print(i)
  1153. '''
  1154. 题目078:找到年龄最大的人,并输出。
  1155. person = {"li":18,"wang":50,"zhang":20,"sun":22}
  1156. '''
  1157. def tm078():
  1158. '''
  1159. 【个人备注】:官网的答案也基本一样。
  1160. '''
  1161. person = { "li": 18, "wang": 50, "zhang": 20, "sun": 22}
  1162. name,age= '', 0
  1163. for p in person.keys():
  1164. if person.get(p)>age:
  1165. name,age=p,person.get(p)
  1166. print(name,age)
  1167. '''
  1168. 题目080:海滩上有一堆桃子,五只猴子来分。
  1169. 第一只猴子把这堆桃子平均分为五份,多了一个,
  1170. 这只猴子把多的一个扔入海中,拿走了一份。
  1171. 第二只猴子把剩下的桃子又平均分成五份,又多了一个,
  1172. 它同样把多的一个扔入海中,拿走了一份,
  1173. 第三、第四、第五只猴子都是这样做的,
  1174. 问海滩上原来最少有多少个桃子?
  1175. '''
  1176. def tm080():
  1177. '''
  1178. 【个人备注】:不考虑解方程什么的,问题实际上归结成
  1179. “整数n,迭代5次之每次都能得到整数,求n的最小值”问题。
  1180. 一开始想简单了,以为最后的猴子只拿一个,代进去一算发现不是整数。
  1181. 于是直接暴力输入,一个个试直到3121,得到整除。
  1182. 当然也可以反着试,假设最后一个猴子拿到n个桃子,remain = lambda t:t/4*5+1,
  1183. 一个个试直到1020,得到整除,也能得出结论,最开始的猴子拿了3121个桃子。
  1184. '''
  1185. for total in range( 10000):
  1186. t = total # 沙滩上有t个桃子
  1187. remain = lambda t:(t -1)/ 5* 4 # 每次分桃后剩余桃子。
  1188. for i in range( 5):
  1189. t = remain(t)
  1190. if t% 1!= 0: break # 如果不是整数,说明不符合题意
  1191. else:
  1192. print(total,t) # 5次都能得到整数,第一个猴子3121,五个猴子拿完沙滩剩余1020个。
  1193. break
  1194. '''
  1195. 题目081:809*??=800*??+9*?? 其中??代表的两位数,
  1196. 809*??为四位数,8*??的结果为两位数,9*??的结果为3位数。
  1197. 求??代表的两位数,及809*??后的结果。
  1198. '''
  1199. def tm081():
  1200. '''
  1201. 假设??为x,因为8*x<100,所以x<13。
  1202. 实际上因为9*x>100,得到x>11,很明显x就是12,题意给的过于充分了。
  1203. 程序如下:
  1204. '''
  1205. l = lambda x:len(str(x))
  1206. for i in range( 20):
  1207. if l( 809*i)== 4 and l( 8*i)== 2 and l( 9*i)== 3:
  1208. x = i
  1209. print(x)
  1210. print( 809*x== 800*x+ 9*x)
  1211. print( 809*x)
  1212. '''
  1213. 题目082:八进制转换为十进制
  1214. '''
  1215. def tm082():
  1216. '''
  1217. 【个人备注】:知道了这些,你就可以随意转了。
  1218. '''
  1219. print(bin( 10)) #十转二
  1220. print(oct( 10)) #十转八
  1221. print(hex( 10)) #十转16
  1222. print(int( '10', 8)) #八转十
  1223. print(int( '10', 2)) #二转十
  1224. print(int( '10', 16)) #16转十
  1225. '''
  1226. 题目083:求0—7所能组成的奇数个数。
  1227. '''
  1228. def tm083():
  1229. '''
  1230. 【个人备注】:没说组成几位数或是否重复使用。假设1-8位都可以,且不能重复使用。
  1231. 直接用排列函数,累加然后去重,就得到答案了。
  1232. '''
  1233. s = [i for i in '01234567']
  1234. import itertools
  1235. arr = []
  1236. for i in range( 1, 9):
  1237. a = list(itertools.permutations(s,i)) # 长度1-8左右排列
  1238. l = list(map( lambda x:int( ''.join(x)),a)) # 整理成数字形式(避免出现02这种情况,02实际上就是2)
  1239. arr+=l
  1240. print(i,len(l))
  1241. arr1 = set(arr) # 去重
  1242. arr2 = list(filter( lambda x:x% 2== 1,arr1)) # 只留奇数
  1243. print(len(arr),len(arr1),len(arr2)) # 答案是46972
  1244. def tm083_1():
  1245. '''
  1246. 【个人备注】: 因为也不知道对错,又用穷举法验证验证了一下
  1247. '''
  1248. count = 0
  1249. for i in range( 76543211): # 能组成的最大数字也就是76543210了
  1250. s = str(i) # 转换成文本形式s
  1251. if '8' in s or '9' in s: # s中不包含8和9
  1252. continue
  1253. else:
  1254. cs = set([c for c in s]) # s中的数字去重,如果去重后和去重前长度一致,说明数字没有重复使用
  1255. if len(s)==len(cs) and s[ -1] in '1357': # 各位不重复且是奇数
  1256. count+= 1
  1257. if i% 100000== 0:print(i,count) # 每10万个输出一下结果,避免程序卡死发现不了。
  1258. print(count) # 公司电脑比较差劲,跑了2分钟多,也出结果了46972。
  1259. '''
  1260. 题目084:连接字符串。
  1261. '''
  1262. def tm084():
  1263. '''
  1264. 【个人备注】: join的用法,之前都已经用过很多次了
  1265. '''
  1266. pass
  1267. '''
  1268. 题目085:输入一个奇数,然后判断最少几个 9 除于该数的结果为整数。
  1269. '''
  1270. def tm085():
  1271. '''
  1272. 【个人备注】:挨个试直到整除为止即可。
  1273. '''
  1274. x = int(input( 'input a number:'))
  1275. for i in range( 1, 61):
  1276. if int( '9'*i)%x== 0:
  1277. print(i)
  1278. break
  1279. else:
  1280. print( 'no way')
  1281. '''
  1282. 题目086:两个字符串连接程序。
  1283. '''
  1284. def tm086():
  1285. # 直接‘+’就行
  1286. pass
  1287. '''
  1288. 题目087:回答结果(结构体变量传递)。
  1289. '''
  1290. def tm087():
  1291. '''
  1292. 没题目没得做
  1293. '''
  1294. pass
  1295. '''
  1296. 题目088:读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*。
  1297. '''
  1298. def tm088():
  1299. # 没啥说的
  1300. for i in [ 1, 4, 5, 14, 22]:
  1301. print( '*'*i)
  1302. '''
  1303. 题目089:某个公司采用公用电话传递数据,数据是四位的整数,
  1304. 在传递过程中是加密的,加密规则如下:
  1305. 每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。
  1306. '''
  1307. def tm089():
  1308. x,c = 1234, 5
  1309. q,b,s,g = x// 1000,x// 100% 10,x// 10% 10,x% 10
  1310. s = (g+c)% 10* 1000+(s+c)% 10* 100+(b+c)% 10* 10+(q+c)% 10
  1311. print(s)
  1312. '''
  1313. 题目090:列表使用实例。
  1314. '''
  1315. def tm090():
  1316. # 没有具体要求
  1317. pass
  1318. '''
  1319. 题目091:时间函数举例1。
  1320. 题目092:时间函数举例2。
  1321. 题目093:时间函数举例3。
  1322. 题目095:字符串日期转换为易读的日期格式。
  1323. '''
  1324. def tm091(): #tm092、tm093、tm095
  1325. # 参看tm016
  1326. pass
  1327. '''
  1328. 题目094:时间函数举例4,一个猜数游戏,判断一个人反应快慢。
  1329. '''
  1330. def tm094():
  1331. import time,random
  1332. print( '《猜大小0-1000之间》')
  1333. x = random.randint( 0, 1000)
  1334. flag = input( '是否开始(y/n):')
  1335. if flag== 'y':
  1336. s = time.time()
  1337. while 1:
  1338. m = int(input( '请输入数字:'))
  1339. if m>x:
  1340. print( '大了')
  1341. elif m<x:
  1342. print( '小了')
  1343. else:
  1344. print( 'bingo!')
  1345. break
  1346. e = time.time()
  1347. print( '耗时%.2f秒'%(e-s))
  1348. print(time.sleep( 5))
  1349. '''
  1350. 题目096:计算字符串中子串出现的次数。
  1351. '''
  1352. def tm096():
  1353. '''
  1354. 【个人备注】:用count就行了
  1355. '''
  1356. x = 'ababaabbaaa'
  1357. print(x.count( 'ab'))
  1358. '''
  1359. 题目097:从键盘输入一些字符,逐个把它们写到磁盘文件上,直到输入一个 # 为止。
  1360. '''
  1361. def tm097():
  1362. '''
  1363. 【个人备注】:保存文件的方法,记住即可。
  1364. with .. as ..打开会自动关闭。
  1365. 其他方式打开,别忘了通过代码关闭。
  1366. '''
  1367. path = 'd:/test.txt'
  1368. with open(path, 'w+') as f:f.write( '')
  1369. while 1:
  1370. c = input()
  1371. if c== '#':
  1372. break
  1373. else:
  1374. with open(path, 'a+') as f:f.write(c)
  1375. '''
  1376. 题目098:从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件"test"中保存。
  1377. '''
  1378. def tm098():
  1379. '''
  1380. 【个人备注】:字符串大写
  1381. '''
  1382. c = input()
  1383. c = c.upper()
  1384. with open( 'd:/test.txt', 'w+') as f:f.write(c)
  1385. '''
  1386. 题目099:有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。
  1387. '''
  1388. def tm099():
  1389. '''
  1390. 【个人备注】:读写文件,题目只限制了字母,实际日常更多可能遇到中文或图片之类的保存。
  1391. 保存文本:ASCII码(数字\英文\英文标点等)以外的字符,需指定编码格式进行保存:
  1392. import codecs
  1393. text = '中文、にほんご、한국어'
  1394. with codecs.open('a.txt','w','utf-8') as f: # 建议保存为utf-8编码
  1395. f.write(text)
  1396. 顺便一提:比如你在Windows上,新建文本文档.txt,用记事本打开然后选择另存,你会看到最下方有一个选项叫编码,里面提供了ANSI、UTF-8等选项,这个就是文档保存的编码格式。
  1397. 有的时候你下载软件、游戏等压缩包,里面的readme.txt文件打开出现乱码,其实就是打开时解码的方式不对,用UTF-8或后面这几种编码试试多半就没有问题了。
  1398. 这里面的ANSI是Windows搞出来的名称,并非指代固定编码。
  1399. ANSI在简体中文系统下代表GB2312编码,在日文系统中代表Shift_JIS编码,韩文系统中是EUC-KR编码,繁体中文系统中是BIG5,换到正确的编码方式就能看了。
  1400. 关于编码我在这里总结了常见的编解码入门:
  1401. https://blog.csdn.net/watfe/article/details/65935342
  1402. 保存图片:如果是下载保存图片之类的数据的,注意用'wb'的方式写入:
  1403. import requests
  1404. r = requests.get('https://www.baidu.com/img/bd_logo1.png')
  1405. img = r.content
  1406. with open('a.png','wb') as f:
  1407. f.write(img)
  1408. '''
  1409. with open( 'd:/a.txt', 'r') as f:a=f.read()
  1410. with open( 'd:/b.txt', 'r') as f:b=f.read()
  1411. with open( 'd:/c.txt', 'w') as f:f.write(a+b)
  1412. '''
  1413. 题目100:列表转换为字典。
  1414. '''
  1415. def tm100():
  1416. '''
  1417. 【个人备注】:终于最后一题完事~,没啥说的。
  1418. '''
  1419. l = [ 'ak17', 'b51', 'b52', '#64']
  1420. d = {}
  1421. for i in range(len(l)):
  1422. d[i]=l[i]
  1423. print(d)
  1424. # 得到:{0: 'ak17', 1: 'b51', 2: 'b52', 3: '#64'}
  1425. def tm100_1():
  1426. # 用zip函数更简单
  1427. l = [ 'ak17', 'b51', 'b52', '#64']
  1428. print(dict(zip(range( 4),l)))
  1429. # 得到:{0: 'ak17', 1: 'b51', 2: 'b52', 3: '#64'}

 

 

 

 

 


转载:https://blog.csdn.net/watfe/article/details/79206165
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场