日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

Python 經(jīng)典算法100及解析

 Four兄 2019-08-29

1:找出字符串s='aaabbbccceeefff111144444'中,字符出現(xiàn)次數(shù)最多的字符

(1)考慮去重,首先將字符串進(jìn)行過濾去重,這樣在根據(jù)這些字符進(jìn)行循環(huán)查詢時,將會減少循環(huán)次數(shù),提升效率。但是本人寫的代碼較為臃腫,有更好的希望留言評論

  1. str = 'a1fsfs111bbbcccccvvvvvnnnnboooooosssnb'
  2. class Countvalue():
  3. def countvalue(self, str1):
  4. '''
  5. 利用set自身的去重功能
  6. :param str1: 對傳進(jìn)來的字符串過濾
  7. :return: 返回一個不含重復(fù)字符的list
  8. '''
  9. list1 = []
  10. result = []
  11. for x in str1:
  12. list1.append(x)
  13. result = set(list1)
  14. return result
  15. def count(self, str1):
  16. '''
  17. 對已經(jīng)去重的list進(jìn)行遍歷,因已去重
  18. 從而減少循環(huán)次數(shù),提高檢索效率
  19. :param str1:
  20. :return:
  21. '''
  22. list = Countvalue().countvalue(str1)
  23. a = 0
  24. tump = {}
  25. for x in list:
  26. test = str1.count(x)
  27. if test > a:
  28. tump.clear()
  29. a = test
  30. tump[x] = a
  31. elif test == a:
  32. a = test
  33. tump[x] = a
  34. return tump
  35. if __name__ == '__main__':
  36. print(Countvalue().count(str))

(2)不考慮去重

  1. s = 'xssdddeeeeeeeffff'
  2. max_times = 0
  3. result = {}
  4. for i in s:
  5. if s.count(i) > max_times:
  6. result.clear()
  7. result[i] = s.count(i)
  8. max_times = s.count(i)
  9. elif s.count(i) == max_times:
  10. result[i] = s.count(i)
  11. print result

以下內(nèi)容摘抄自:https://blog.csdn.net/watfe/article/details/79206165

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

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多