乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

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

       Four兄 2019-08-29

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

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

      1. str = 'a1fsfs111bbbcccccvvvvvnnnnboooooosssnb'
      2. class Countvalue():
      3. def countvalue(self, str1):
      4. '''
      5. 利用set自身的去重功能
      6. :param str1: 對(duì)傳進(jìn)來(lái)的字符串過(guò)濾
      7. :return: 返回一個(gè)不含重復(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. 對(duì)已經(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:有四個(gè)數(shù)字:1、2、3、4,能組成多少個(gè)互不相同且無(wú)重復(fù)數(shù)字的三位數(shù)?各是多少?
      10. '''
      11. def tm001():
      12. '''
      13. 【個(gè)人備注】:按題意直接寫(xiě)出來(lái)
      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:# 互不相同且無(wú)重復(fù)數(shù)字的三位數(shù)
      21. arr.append(num)
      22. print(len(arr),arr)
      23. def tm001_1():
      24. '''
      25. 【個(gè)人備注】:其實(shí)python自帶排列組合模塊,可以直接調(diào)用。
      26. 也知道這個(gè)寫(xiě)法,只是函數(shù)記不住,還是百度一下才能寫(xiě)出來(lái)。
      27. 如果這是面試題,能寫(xiě)出后一種當(dāng)然好,不能的話還是老老實(shí)實(shí)的按照上面的思路來(lái)吧。
      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ā)放的獎(jiǎng)金根據(jù)利潤(rùn)(I)的多少來(lái)提成:
      35. 低于或等于10萬(wàn)元時(shí),獎(jiǎng)金可提10%;
      36. 利潤(rùn)高于10萬(wàn)元,低于20萬(wàn)元時(shí),低于10萬(wàn)元的部分按10%提成,高于10萬(wàn)元的部分,可提成7.5%;
      37. 20萬(wàn)到40萬(wàn)之間時(shí),高于20萬(wàn)元的部分,可提成5%;
      38. 40萬(wàn)到60萬(wàn)之間時(shí)高于40萬(wàn)元的部分,可提成3%;
      39. 60萬(wàn)到100萬(wàn)之間時(shí),高于60萬(wàn)元的部分,可提成1.5%;
      40. 高于100萬(wàn)元時(shí),超過(guò)100萬(wàn)元的部分按1%提成。
      41. 從鍵盤輸入當(dāng)月利潤(rùn)I,求應(yīng)發(fā)放獎(jiǎng)金總數(shù)?
      42. '''
      43. def tm002():
      44. '''
      45. 程序分析:請(qǐng)利用數(shù)軸來(lái)分界,定位。
      46. 【個(gè)人備注】:這種處理數(shù)軸問(wèn)題的寫(xiě)法,值得參考。比elif的寫(xiě)法,簡(jiǎn)潔方便的多。
      47. '''
      48. money = int(input('凈利潤(rùn):'))
      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]: # 對(duì)于處于區(qū)間的部分
      54. bonus+=(money-arr[i])*rat[i] # 計(jì)算并累加獎(jiǎng)勵(lì)
      55. money=arr[i] # 剩余部分
      56. print(bonus)
      57. '''
      58. 題目003:一個(gè)整數(shù),它加上100后是一個(gè)完全平方數(shù),再加上168又是一個(gè)完全平方數(shù),請(qǐng)問(wèn)該數(shù)是多少?
      59. '''
      60. def tm003():
      61. '''
      62. 【個(gè)人備注】:網(wǎng)站上是求了一下方程,沒(méi)細(xì)看。
      63. python又不是沒(méi)有開(kāi)方函數(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. 【個(gè)人備注】:知道python有時(shí)間元組這一概念,這道題完全不需要計(jì)算。
      77. 時(shí)間元組包含九個(gè)屬性
      78. tm_year 年
      79. tm_mon 月(1~12)
      80. tm_mday 日(1~31)
      81. tm_hour 時(shí)(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 夏令時(shí)(平時(shí)用不到)
      87. '''
      88. import time
      89. date = input('輸入時(shí)間(例如2018-01-23):')
      90. st = time.strptime(date,'%Y-%m-%d') # 時(shí)間文本轉(zhuǎn)化成時(shí)間元祖
      91. num = st.tm_yday
      92. print(num)
      93. '''
      94. 題目005:輸入三個(gè)整數(shù)x,y,z,請(qǐng)把這三個(gè)數(shù)由小到大輸出。
      95. '''
      96. def tm005():
      97. print('輸入三個(gè)數(shù)字')
      98. x = input('輸入第1個(gè)數(shù)字:')
      99. y = input('輸入第2個(gè)數(shù)字:')
      100. z = input('輸入第3個(gè)數(shù)字:')
      101. l = [x,y,z]
      102. arr = sorted(l) # 你也可以使用list.sort()方法來(lái)排序,此時(shí)list本身將被修改
      103. print(arr)
      104. '''
      105. 題目006:斐波那契數(shù)列。
      106. '''
      107. def tm006():
      108. '''
      109. 程序分析:斐波那契數(shù)列,又稱黃金分割數(shù)列,指的是這樣一個(gè)數(shù)列:0、1、1、2、3、5、8、13、21、34、……。
      110. 【個(gè)人備注】:很多種解法,我是按照分割的方式,每次取列表后兩項(xiàng),然后相加。
      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:將一個(gè)列表的數(shù)據(jù)復(fù)制到另一個(gè)列表中。
      119. '''
      120. def tm007():
      121. '''
      122. 【個(gè)人備注】:如果系統(tǒng)的看過(guò)python教程之類的應(yīng)該都知道。
      123. Python里面一切都是對(duì)象,list的復(fù)制需要用[:]的方式。
      124. 至于b=a只是相當(dāng)于給a取了個(gè)別名而已,指向的是同一個(gè)列表,并沒(méi)有實(shí)現(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)存一致,并沒(méi)有復(fù)制,指向的是同一個(gè)列表
      136. print(a,b) # 修改a,b也變
      137. '''
      138. 題目008:題目:輸出 9*9 乘法口訣表。
      139. '''
      140. def tm008():
      141. '''
      142. 【個(gè)人備注】:已經(jīng)忘了,百度了才想起來(lái)口訣表具體長(zhǎng)什么樣。
      143. 注意 %-7s 和 end='' 的用法,其他沒(méi)什么。
      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的方法,比上面還能少寫(xiě)一行。
      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. 【個(gè)人備注】:time.sleep(),用過(guò)的都知道。
      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)前時(shí)間。
      174. '''
      175. def tm010():
      176. '''
      177. 【個(gè)人備注】:用過(guò)幾次,用過(guò)就忘。
      178. '''
      179. import time
      180. a = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.localtime()時(shí)間戳轉(zhuǎn)化成時(shí)間元祖
      181. print(a)
      182. time.sleep(1)
      183. b = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.strftime()時(shí)間元祖轉(zhuǎn)化成時(shí)間文本
      184. print(b)
      185. '''
      186. 題目011:古典問(wèn)題:
      187. 有一對(duì)兔子,
      188. 從出生后第3個(gè)月起每個(gè)月都生一對(duì)兔子,
      189. 小兔子長(zhǎng)到第三個(gè)月后每個(gè)月又生一對(duì)兔子。
      190. 假如兔子都不死。
      191. 問(wèn)每個(gè)月的兔子總數(shù)為多少?
      192. '''
      193. def tm011():
      194. '''
      195. 其實(shí)這道題就是斐波那契數(shù)列的由來(lái)。
      196. 【個(gè)人備注】:理清思路是關(guān)鍵,理解成滿兩個(gè)月后,每月都能生兔子,就好辦了。
      197. '''
      198. m1=1 # 滿月
      199. m2=0 # 滿倆月(下個(gè)月生兔子)
      200. mm=0 # 可以月月生兔子了
      201. for i in range(1,10):
      202. # 過(guò)了1個(gè)月后
      203. mm = mm+m2 # 加入新增成年的兔子
      204. m2 = m1 # 滿月的變成滿倆月
      205. m1 = mm # 這個(gè)月新出生兔子
      206. print(i,mm+m1+m2) # 每個(gè)月有多少對(duì)兔子
      207. '''
      208. 題目012:判斷101-200之間有多少個(gè)素?cái)?shù),并輸出所有素?cái)?shù)。
      209. '''
      210. def tm012():
      211. '''
      212. 【個(gè)人備注】:按照素?cái)?shù)不能被之前的素?cái)?shù)整除,取200以內(nèi)所有素?cái)?shù),然后取出101-200之間的部分。
      213. '''
      214. arr = [2,3]
      215. # 取200以內(nèi)所有素?cái)?shù)
      216. for i in range(4,201):
      217. for j in arr:
      218. if i%j==0:
      219. break
      220. # else: # 這是一開(kāi)始我自己的寫(xiě)法,后來(lái)發(fā)現(xiàn)for可以直接接else子語(yǔ)句
      221. # if j==arr[-1]:
      222. # arr.append(i)
      223. else: # 迭代的對(duì)象成功迭代完,位于else的子句將執(zhí)行;而如果在for循環(huán)中含有break時(shí)則直接終止循環(huán),并不會(huì)執(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ù)'是指一個(gè)三位數(shù),其各位數(shù)字立方和等于該數(shù)本身。
      234. 例如:153是一個(gè)'水仙花數(shù)',因?yàn)?53=1的三次方+5的三次方+3的三次方。
      235. '''
      236. def tm013():
      237. '''
      238. 【個(gè)人備注】: // 取整,% 求余,**3 三次方。知道取整求余寫(xiě)法的就沒(méi)問(wèn)題。
      239. '''
      240. for i in range(100,1000):
      241. b = i//100 # 百位
      242. s = i%100//10 # 十位
      243. g = i%10 # 個(gè)位
      244. if b**3+s**3+g**3==i:
      245. print(i)
      246. '''
      247. 題目014:將一個(gè)正整數(shù)分解質(zhì)因數(shù)。例如:輸入90,打印出90=2*3*3*5。
      248. '''
      249. def tm014():
      250. '''
      251. 【個(gè)人備注】:拆到拆不動(dòng)為止,類似012題。
      252. '''
      253. import math
      254. num = int(input('輸入一個(gè)整數(shù):'))
      255. arr = []
      256. while num>1:
      257. for i in range(2,int(math.sqrt(num))+1): # 因?yàn)轭}目是一個(gè)沒(méi)寫(xiě)范圍正整數(shù),開(kāi)方可以有效減少該值過(guò)大時(shí)候的計(jì)算量
      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:利用條件運(yùn)算符的嵌套來(lái)完成此題:學(xué)習(xí)成績(jī)>=90分的同學(xué)用A表示,60-89分之間的用B表示,60分以下的用C表示。
      268. '''
      269. def tm015():
      270. '''
      271. 【個(gè)人備注】:if-else基本用法,沒(méi)啥說(shuō)的。
      272. '''
      273. score = float(input('輸入一個(gè)成績(jī):'))
      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. 【個(gè)人備注】:用的不多經(jīng)常忘,整理了一下參考答案和一些轉(zhuǎn)換
      286. 2019-5-29 以下日期時(shí)間代碼僅供參考。
      287. 我將常用的日期時(shí)間方法,整理到了我的另一篇博客中
      288. 《Python3 日期文本互轉(zhuǎn),時(shí)間戳,時(shí)間差 以及 時(shí)區(qū)變換》
      289. https://blog.csdn.net/watfe/article/details/84943732
      290. '''
      291. import time
      292. print(time.time()) # 時(shí)間戳 1498539133.655
      293. print(time.localtime()) # 時(shí)間元祖 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()) # 時(shí)間的一種可讀文本形式 'Tue Jun 27 12:53:50 2017'
      295. print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())) # 按指定文本格式輸出時(shí)間 '2017-06-27 13:00:57'
      296. st = time.localtime(time.time()) # 時(shí)間戳 轉(zhuǎn)化成 時(shí)間元祖
      297. st = time.strptime('2018/1/23','%Y/%m/%d') # 時(shí)間文本 轉(zhuǎn)化成 時(shí)間元祖
      298. date = time.strftime('%Y-%m-%d',st) # 時(shí)間元祖 轉(zhuǎn)化成 時(shí)間文本 '%Y-%m-%d %H:%M:%S'
      299. print(date) # 前面兩條函數(shù)配合著用,相當(dāng)于將時(shí)間文本重新格式化。
      300. # 另外我們可以通過(guò)datetime模塊來(lái)計(jì)算時(shí)間差,例如:
      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個(gè)小時(shí)'%((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個(gè)小時(shí)
      311. '''
      312. # 注意上面的日期雖然看起來(lái)是文本,但實(shí)際上是datetime類型的。
      313. # 可以通過(guò)時(shí)間戳/時(shí)間文本轉(zhuǎn)換得到,然后才能進(jìn)行日期時(shí)間計(jì)算。
      314. d1 = datetime.datetime.strptime('2017-10-16 19:21:22', '%Y-%m-%d %H:%M:%S')
      315. '''
      316. 題目017:輸入一行字符,分別統(tǒng)計(jì)出其中英文字母、空格、數(shù)字和其它字符的個(gè)數(shù)。
      317. '''
      318. def tm017():
      319. '''
      320. 【個(gè)人備注】:本來(lái)想寫(xiě)成這種格式來(lái)著
      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. 其實(shí)隨便哪種都行,甚至直接把一串字母粘上去看起來(lái)更直接。
      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是一個(gè)數(shù)字。例如2+22+222+2222+22222(此時(shí)共有5個(gè)數(shù)相加),幾個(gè)數(shù)相加由鍵盤控制。
      342. '''
      343. def tm018():
      344. '''
      345. 【個(gè)人備注】:答案給的解法很多種,但是我還是認(rèn)為我寫(xiě)的方法最簡(jiǎ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ǎn)單迭代就可以出結(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:一個(gè)數(shù)如果恰好等于它的因子之和,這個(gè)數(shù)就稱為'完數(shù)'。例如6=1+2+3.編程找出1000以內(nèi)的所有完數(shù)。
      361. '''
      362. def tm019():
      363. '''
      364. 【個(gè)人備注】:題意看的不是太懂,于是百度了一下:完數(shù)就是除了自身之外的所有約數(shù)之和等于他本身。
      365. 第一個(gè)完全數(shù)是6,它有約數(shù)1、2、3、6,除去它本身6外,其余3個(gè)數(shù)相加,1+2+3=6。
      366. 第二個(gè)完全數(shù)是28,它有約數(shù)1、2、4、7、14、28,除去它本身28外,其余5個(gè)數(shù)相加,1+2+4+7+14=28。
      367. 終于看懂了題意。
      368. 先求出所有約數(shù),然后求和比一下是否相等就行了,沒(méi)有難度
      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次落地時(shí),共經(jīng)過(guò)多少米?第10次反彈多高?
      379. '''
      380. def tm020():
      381. '''
      382. 【個(gè)人備注】:很簡(jiǎn)單,沒(méi)啥說(shuō)的
      383. '''
      384. total = 0
      385. m = 100 # 第一次落地,經(jīng)過(guò)了一百米
      386. total += m
      387. for i in range(10-1): # 之后9次彈起到落地
      388. m = m/2 # 彈起的高度
      389. total += 2*m # 彈起然后重新落地,一共經(jīng)過(guò)的距離
      390. print(total)
      391. print(m/2)
      392. '''
      393. 題目021:猴子吃桃問(wèn)題
      394. 猴子第一天摘下若干個(gè)桃子,當(dāng)即吃了一半,還不癮,又多吃了一個(gè)
      395. 第二天早上又將剩下的桃子吃掉一半,又多吃了一個(gè)。
      396. 以后每天早上都吃了前一天剩下的一半零一個(gè)。
      397. 到第10天早上想再吃時(shí),見(jiàn)只剩下一個(gè)桃子了。
      398. 求第一天共摘了多少。
      399. '''
      400. def tm021():
      401. '''
      402. 【個(gè)人備注】:第十天num=1個(gè),第九天必然是4個(gè):4/2-1=1,也就是(num+1)*2=4。
      403. 做這種題,先用算數(shù)式列出來(lái),然后用代碼描述就行了。
      404. '''
      405. num = 1
      406. for i in range(10-1):
      407. num = (num+1)*2
      408. print(num)
      409. '''
      410. 題目022:兩個(gè)乒乓球隊(duì)進(jìn)行比賽,各出三人。
      411. 甲隊(duì)為a,b,c三人,乙隊(duì)為x,y,z三人。
      412. 已抽簽決定比賽名單。有人向隊(duì)員打聽(tīng)比賽的名單。
      413. a說(shuō)他不和x比,c說(shuō)他不和x,z比,請(qǐng)編程序找出三隊(duì)賽手的名單。
      414. '''
      415. def tm022():
      416. '''
      417. 【個(gè)人備注】:關(guān)鍵是將抽象化,將問(wèn)題抽象成代碼方式。
      418. 我的解題思路,是用排列組合函數(shù),列出方案,然后排除。
      419. 而官方解答里面有一個(gè)純粹的for循環(huán)加if的求解方式,
      420. 更抽象一些,用了一個(gè)很常用固定范式,直接拿來(lái)解題了。
      421. 稍微對(duì)其抽象的方法注釋了一下。
      422. '''
      423. import itertools
      424. jia = ['a','b','c']
      425. yi = ['x','y','z']
      426. arr = list(itertools.permutations(yi,3)) # 面對(duì)甲隊(duì)a,b,c時(shí),乙隊(duì)所有排列 [('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寫(xiě)上,得到所有對(duì)陣組合 [['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中挑一個(gè)打
      437. for b in ['x', 'y', 'z']: # b在x,y,z中挑一個(gè)打
      438. for c in ['x', 'y', 'z']: # c在x,y,z中挑一個(gè)打 三層總計(jì)27種打法
      439. if a!=b and b!=c and c!=a: # a,b,c不能挑同一個(gè)人 縮減到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. 【個(gè)人備注】:想到了絕對(duì)值,
      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...求出這個(gè)數(shù)列的前20項(xiàng)之和。
      464. '''
      465. def tm024():
      466. '''
      467. 沒(méi)啥好說(shuō)的
      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. 【個(gè)人備注】:實(shí)現(xiàn)起來(lái)很簡(jiǎn)單。
      481. 下面官方的代碼,比我寫(xiě)的更簡(jiǎn)潔。
      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. 【個(gè)人備注】:按題目要求,公式f(n)=n*f(n-1),遞歸調(diào)用求解。
      499. '''
      500. print(fac(5))
      501. '''
      502. 題目027:利用遞歸函數(shù)調(diào)用方式,將所輸入的5個(gè)字符,以相反順序打印出來(lái)。
      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. 【個(gè)人備注】:直接從官網(wǎng)復(fù)制,不喜歡遞歸。
      512. '''
      513. s = input('Input a string:')
      514. l = len(s)
      515. output(s,l)
      516. '''
      517. 題目028:有5個(gè)人坐在一起,
      518. 問(wèn)第五個(gè)人多少歲?他說(shuō)比第4個(gè)人大兩歲。
      519. 問(wèn)第4個(gè)人,他說(shuō)比第3個(gè)人大兩歲。
      520. 問(wèn)第3個(gè)人,又說(shuō)比第2個(gè)人大兩歲。
      521. 問(wèn)第2個(gè)人,說(shuō)比第1個(gè)人大兩歲。
      522. 最后問(wèn)第一個(gè)人,他說(shuō)是10歲。
      523. 請(qǐng)問(wèn)第五個(gè)人多大?
      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. 【個(gè)人備注】:官網(wǎng)給的還是遞歸方法,因?yàn)椴挥眠f歸的話就是個(gè)口算題。
      533. '''
      534. print(age(5))
      535. '''
      536. 題目029:給一個(gè)不多于5位的正整數(shù),要求:一、求它是幾位數(shù),二、逆序打印出各位數(shù)字。
      537. '''
      538. def tm029():
      539. '''
      540. 【個(gè)人備注】:用Python,So Easy~
      541. list倒序可以用list.reverse();
      542. 字符串就只能用步長(zhǎng)=-1的方式來(lái)倒序了。
      543. '''
      544. num = 12345
      545. s = str(num)
      546. print(len(s))
      547. print(s[::-1])
      548. '''
      549. 題目030:一個(gè)5位數(shù),判斷它是不是回文數(shù)。即12321是回文數(shù),個(gè)位與萬(wàn)位相同,十位與千位相同。
      550. '''
      551. def tm030():
      552. '''
      553. 【個(gè)人備注】:沒(méi)啥可說(shuō)的。
      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:請(qǐng)輸入星期幾的第一個(gè)字母來(lái)判斷一下是星期幾,如果第一個(gè)字母一樣,則繼續(xù)判斷第二個(gè)字母。
      565. '''
      566. def tm031():
      567. '''
      568. 【個(gè)人備注】:按照題意要求實(shí)現(xiàn)了就行
      569. '''
      570. week = ['monday','tuesday','wednesday','thursday','friday','saturday','sunday']
      571. inp = ''
      572. while 1:
      573. arr = []
      574. inp = inp+input('請(qǐng)輸入一個(gè)字母:')
      575. for day in week: # 挑出滿足輸入的星期
      576. if inp==day[:len(inp)]:
      577. arr.append(day)
      578. if len(arr)==1: # 只剩一個(gè),說(shuō)明唯一,可以輸出結(jié)果
      579. print('以%s開(kāi)頭的單詞是:%s'%(inp,arr[0]))
      580. inp=''
      581. elif len(arr)==0: # 一個(gè)都沒(méi)有說(shuō)明輸錯(cuò)了,需要重新輸入
      582. print('沒(méi)有%s開(kāi)頭的單詞'%inp)
      583. inp=''
      584. '''
      585. 題目032:按相反的順序輸出列表的值。
      586. '''
      587. def tm032():
      588. '''
      589. 【個(gè)人備注】:之前已經(jīng)做過(guò)了
      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:按逗號(hào)分隔列表。
      604. '''
      605. def tm033():
      606. '''
      607. 【個(gè)人備注】:一開(kāi)始沒(méi)看懂題目項(xiàng)干啥,直接print(list)不就是逗號(hào)分隔么
      608. 實(shí)際上題目的意思是,合并列表項(xiàng),以逗號(hào)為間隔
      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. 【個(gè)人備注】:沒(méi)頭沒(méi)尾的一個(gè)題,之前的遞歸實(shí)際上就是函數(shù)的調(diào)用了。不寫(xiě)了。
      618. '''
      619. pass
      620. '''
      621. 題目035:文本顏色設(shè)置。
      622. '''
      623. def tm035():
      624. '''
      625. 【個(gè)人備注】:感覺(jué)不像是不是python的題。
      626. '''
      627. pass
      628. '''
      629. 題目036:求100之內(nèi)的素?cái)?shù)。
      630. '''
      631. def tm036():
      632. '''
      633. 【個(gè)人備注】:素?cái)?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:對(duì)10個(gè)數(shù)進(jìn)行排序。
      645. '''
      646. def tm037():
      647. '''
      648. 【個(gè)人備注】:實(shí)際上考察的是排序。揣測(cè)了一下題意,寫(xiě)了兩種解法
      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:求一個(gè)3*3矩陣主對(duì)角線元素之和。
      667. '''
      668. def tm038():
      669. '''
      670. 【個(gè)人備注】:思路比較簡(jiǎn)單,n*n的矩陣都可以用這個(gè)求解。
      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ù)計(jì)算的中間點(diǎn)
      680. s-=a[n//2][n//2]
      681. print(s)
      682. '''
      683. 題目039:有一個(gè)已經(jīng)排好序的數(shù)組?,F(xiàn)輸入一個(gè)數(shù),要求按原來(lái)的規(guī)律將它插入數(shù)組中。
      684. '''
      685. def tm039():
      686. '''
      687. 【個(gè)人備注】:037題中剛寫(xiě)過(guò)。
      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:將一個(gè)數(shù)組逆序輸出。
      700. '''
      701. def tm040():
      702. '''
      703. 【個(gè)人備注】:就是032題,重復(fù)了。
      704. '''
      705. pass
      706. '''
      707. 題目041:模仿靜態(tài)變量的用法。
      708. '''
      709. def tm041():
      710. '''
      711. 【個(gè)人備注】:不是很清楚什么意思,直接看了官網(wǎng)的解答。
      712. 如果是函數(shù)中的局部變量,每次調(diào)用函數(shù)都會(huì)初始化。
      713. 而類中的變量,創(chuàng)建類的時(shí)候初始化,每次執(zhí)行類中的函數(shù)的時(shí)候,不會(huì)初始化類變量。
      714. 看起來(lái)是想說(shuō)這么個(gè)意思。
      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作為類的一個(gè)屬性,相當(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. 【個(gè)人備注】:同樣沒(méi)看懂題意,看了下官網(wǎng)答案
      739. 發(fā)現(xiàn)實(shí)際是想說(shuō)變量作用域, 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. 以上實(shí)例輸出結(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. 【個(gè)人備注】:官網(wǎng)的答案和041沒(méi)啥區(qū)別,又來(lái)一遍
      765. '''
      766. '''
      767. 題目044:兩個(gè)3*3的矩陣,實(shí)現(xiàn)其對(duì)應(yīng)位置的數(shù)據(jù)相加,并返回一個(gè)新矩陣:
      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. 【個(gè)人備注】:自己寫(xiě)了一個(gè),但是印象里python是有矩陣計(jì)算工具的。
      778. 官網(wǎng)就有人用該工具numpy寫(xiě)了一下,很簡(jiǎn)潔。
      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)計(jì) 1 到 100 之和。
      795. '''
      796. def tm045():
      797. '''
      798. 【個(gè)人備注】:簡(jiǎn)單,但官網(wǎng)有人寫(xiě)的更簡(jiǎn)單
      799. '''
      800. s = 0
      801. for i in range(1,101):
      802. s+=i
      803. print(s)
      804. # 更簡(jiǎn)潔的方法
      805. print(sum(range(1,101)))
      806. '''
      807. 題目046:求輸入數(shù)字的平方,如果平方運(yùn)算后小于 50 則退出。
      808. '''
      809. def tm046():
      810. '''
      811. 【個(gè)人備注】:簡(jiǎn)單
      812. '''
      813. while 1:
      814. x= input('輸入數(shù)字得到平方值:')
      815. print(x*x)
      816. if x*x<50:
      817. break
      818. '''
      819. 題目047:兩個(gè)變量值互換。
      820. '''
      821. def tm047():
      822. '''
      823. 【個(gè)人備注】:很簡(jiǎn)單
      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. 【個(gè)人備注】:看了一眼官網(wǎng)答案,簡(jiǎn)單到懶得寫(xiě)。以下官網(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來(lái)創(chuàng)建匿名函數(shù)。
      847. '''
      848. def tm049():
      849. '''
      850. 【個(gè)人備注】:用的不多又忘了,看了一下網(wǎng)上的教程,整理了一下。
      851. '''
      852. #lambda函數(shù)也叫匿名函數(shù),即,函數(shù)沒(méi)有具體的名稱。先來(lái)看一個(gè)最簡(jiǎn)單例子:
      853. def f(x):
      854. return x**2
      855. print(f(4))
      856. #Python中使用lambda的話,寫(xiě)成這樣
      857. g = lambda x:x**2
      858. print(g(4))
      859. #lambda存在意義就是對(duì)簡(jiǎn)單函數(shù)的簡(jiǎn)潔表示。
      860. #lambda語(yǔ)句中,冒號(hào)前是參數(shù),可以有多個(gè),用逗號(hào)隔開(kāi),冒號(hào)右邊的返回值。
      861. #常搭配內(nèi)置函數(shù)map、filter、reduce,都是應(yīng)用于序列的內(nèi)置函數(shù)。常見(jiàn)的序列包括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))) # 過(guò)濾 [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:輸出一個(gè)隨機(jī)數(shù)。
      872. '''
      873. def tm050():
      874. '''
      875. 【個(gè)人備注】:之前學(xué)習(xí)隨機(jī)的時(shí)候整理的東西,用到時(shí)候來(lái)找就行了
      876. '''
      877. import random
      878. # 隨機(jī)數(shù)操作
      879. random.random() # 0.85415370477785668 # 隨機(jī)一個(gè)[0,1)之間的浮點(diǎn)數(shù)
      880. random.uniform(0, 100) # 18.7356606526 # 隨機(jī)一個(gè)[0,100]之間的浮點(diǎn)數(shù)
      881. random.randrange(0, 100, 2) # 44 # 隨機(jī)一個(gè)[0,100)之間的偶數(shù)
      882. random.randint(0, 100) # 22 # 隨機(jī)一個(gè)[0,100]之間的整數(shù)
      883. # 隨機(jī)字符操作
      884. seed = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+=-' # 任意字符串(作為隨機(jī)字符種子庫(kù))
      885. random.choice(seed) # 'd' # 隨機(jī)一個(gè)字符
      886. random.sample(seed, 3) # ['a', 'd', 'b'] # 隨機(jī)多個(gè)字符(字符可重復(fù))
      887. ''.join(random.sample(seed,3)) # '^f^' # 隨機(jī)指定長(zhǎng)度字符串(字符可重復(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. 【個(gè)人備注】:大概看了一下資料,按位操作可以通過(guò)bin()函數(shù)轉(zhuǎn)換為二進(jìn)制從而實(shí)現(xiàn)。
      900. 感覺(jué)二進(jìn)制的計(jì)算如果不是學(xué)加密之類的基本用不上。
      901. 所以這一題,大概寫(xiě)了集合的用法,&、|在python中是集合set()才用的符號(hào)
      902. 兩個(gè)列表求交集并集,通常也都是轉(zhuǎn)換為集合,然后進(jìn)行計(jì)算的。
      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)然也可以寫(xiě)成函數(shù)形式,不過(guò)確實(shí)沒(méi)有上面符號(hào)好記。
      913. print(x.intersection(y))
      914. print(x.union(y))
      915. print(x.difference(y))
      916. '''
      917. 題目054:取一個(gè)整數(shù)a從右端開(kāi)始的4-7位。
      918. '''
      919. def tm054():
      920. '''
      921. 【個(gè)人備注】:官網(wǎng)答案不對(duì)
      922. '''
      923. a = 123456789
      924. b = str(a)
      925. print(b[-7:-3]) # 寫(xiě)的時(shí)候注意一下python切片是[-7:-4)左閉右開(kāi)的,不包含[-4]的,所以要寫(xiě)成-3才能取到
      926. '''
      927. 題目056:畫(huà)圖,學(xué)用circle畫(huà)圓形。
      928. 題目057:畫(huà)圖,學(xué)用line畫(huà)直線。
      929. 題目058:畫(huà)圖,學(xué)用rectangle畫(huà)方形。
      930. 題目059:畫(huà)圖,綜合例子。
      931. 題目063:畫(huà)橢圓。
      932. 題目064:利用ellipse 和 rectangle 畫(huà)圖。
      933. 題目065:一個(gè)最優(yōu)美的圖案。 
      934. 所有畫(huà)圖題pass 有愛(ài)的自己參照下面,將官網(wǎng)答案改成python3運(yùn)行即可。
      935. '''
      936. def tm056(): # tm057、tm058、tm059、tm063、tm064、tm065、
      937. '''
      938. 【個(gè)人備注】:這個(gè)技能感覺(jué)用不上啊。
      939. 復(fù)制了官網(wǎng)Python2答案,調(diào)整一下放到python3上成功運(yùn)行了。
      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:計(jì)算字符串長(zhǎng)度?!?/span>
      953. '''
      954. def tm060():
      955. '''
      956. 【個(gè)人備注】:無(wú)
      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. 【個(gè)人備注】:感覺(jué)自己寫(xiě)的比官網(wǎng)簡(jiǎn)單好懂
      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個(gè)數(shù)a,b,c,按大小順序輸出。
      993. '''
      994. def tm066():
      995. arr=[]
      996. for i in range(3):
      997. a = input('請(qǐng)輸入數(shù)字:')
      998. arr.append(int(a))
      999. arr.sort(reverse=True)
      1000. print('從大到小',arr)
      1001. '''
      1002. 題目067:輸入數(shù)組,最大的與第一個(gè)元素交換,最小的與最后一個(gè)元素交換,輸出數(shù)組。
      1003. '''
      1004. def tm067():
      1005. '''
      1006. 【個(gè)人備注】:感覺(jué)自己寫(xiě)的比官網(wǎng)簡(jiǎn)單好懂,直接用python思維寫(xiě),確實(shí)很方便
      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個(gè)整數(shù),使其前面各數(shù)順序向后移m個(gè)位置,最后m個(gè)數(shù)變成最前面的m個(gè)數(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個(gè)人圍成一圈,順序排號(hào)。
      1024. 從第一個(gè)人開(kāi)始報(bào)數(shù)(從1到3報(bào)數(shù)),凡報(bào)到3的人退出圈子,問(wèn)最后留下的是原來(lái)第幾號(hào)的那位。
      1025. '''
      1026. def tm069():
      1027. '''
      1028. 【個(gè)人備注】:python基礎(chǔ)變量沒(méi)有這種圈狀循環(huán)的。
      1029. 最直接的方法是列表,點(diǎn)隊(duì)尾再?gòu)念^開(kāi)始。
      1030. 缺點(diǎn)是列表刪除中間項(xiàng),后面的索引值都會(huì)變,需要計(jì)算。
      1031. 所以我換了種方法,
      1032. 把問(wèn)題抽象成排隊(duì)進(jìn)門的問(wèn)題
      1033. 完全不考慮索引問(wèn)題。
      1034. '''
      1035. # 初始化
      1036. n = 34
      1037. arr = list(range(1,n+1)) # 所有人門外站成一隊(duì)【a】,進(jìn)門后依舊按序站好【b】
      1038. count,a,b = 0,arr,[]
      1039. # 開(kāi)始解題
      1040. while len(a+b)>1: # 循環(huán)直到只剩1人
      1041. num,count=a.pop(0),count+1 # 排隊(duì)進(jìn)門,每進(jìn)一人【a.pop】,按一下計(jì)數(shù)器
      1042. if count%3!=0:b.append(num) # 進(jìn)門后依舊按序站好【b.append】,計(jì)數(shù)器逢3淘汰。
      1043. if a==[]:a,b=b,[] # 如果門外沒(méi)人了【a=[]】,所有人重新到門外站好【a=b】
      1044. print(a[0])
      1045. '''
      1046. 題目070:寫(xiě)一個(gè)函數(shù),求一個(gè)字符串的長(zhǎng)度,在main函數(shù)中輸入字符串,并輸出其長(zhǎng)度。
      1047. '''
      1048. def tm070():
      1049. '''
      1050. 【個(gè)人備注】:簡(jiǎn)單
      1051. '''
      1052. def getlength(string):
      1053. return len(string)
      1054. if __name__ == '__main__':
      1055. x = 'abcde'
      1056. print(getlength(x))
      1057. '''
      1058. 題目071:編寫(xiě)input()和output()函數(shù)輸入,輸出5個(gè)學(xué)生的數(shù)據(jù)記錄。
      1059. '''
      1060. def tm071():
      1061. '''
      1062. 【個(gè)人備注】:用字典類型隨便寫(xiě)寫(xiě)
      1063. '''
      1064. def inp(data):
      1065. name = input('輸入學(xué)生姓名:')
      1066. score = input('輸入學(xué)生成績(jī):')
      1067. data[name]=score
      1068. print('成功錄入')
      1069. return data
      1070. def outp(data):
      1071. name = input('輸入學(xué)生姓名:')
      1072. print('該學(xué)生的成績(jī)是:',data.get(name))
      1073. return data
      1074. if __name__ == '__main__':
      1075. data = {}
      1076. while 1:
      1077. a = input('輸入/輸出學(xué)生成績(jī)(i/o):')
      1078. if a=='i':
      1079. data = inp(data)
      1080. elif a=='o':
      1081. data = outp(data)
      1082. else:
      1083. print('輸入值不對(duì)')
      1084. '''
      1085. 題目072:創(chuàng)建一個(gè)鏈表。
      1086. 題目073:反向輸出一個(gè)鏈表。
      1087. '''
      1088. def tm072():
      1089. '''
      1090. 【個(gè)人備注】:已經(jīng)幾乎忘了鏈表了,網(wǎng)上搜了一下終于想起鏈表是什么來(lái)著。
      1091. 這種底層的東西,完全沒(méi)必要用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. 【個(gè)人備注】:之前都用過(guò)
      1102. '''
      1103. a = [3,2,1]
      1104. b = [4,5,6]
      1105. a.sort()
      1106. print(a)
      1107. print(a+b)
      1108. '''
      1109. 題目075:放松一下,算一道簡(jiǎn)單的題目。
      1110. '''
      1111. def tm075():
      1112. '''
      1113. 【個(gè)人備注】:Σ( ° △ °|||)︴,不是我偷工減料,題目就是這個(gè),后面太監(jiān)了
      1114. '''
      1115. pass
      1116. '''
      1117. 題目076:編寫(xiě)一個(gè)函數(shù),輸入n為偶數(shù)時(shí),調(diào)用函數(shù)求1/2+1/4+...+1/n,當(dāng)輸入n為奇數(shù)時(shí),調(diào)用函數(shù)1/1+1/3+...+1/n
      1118. '''
      1119. def tm076():
      1120. '''
      1121. 【個(gè)人備注】:學(xué)了lambda想耍一下,結(jié)果發(fā)現(xiàn)官網(wǎng)寫(xiě)的比我還簡(jiǎn)潔!
      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. 【個(gè)人備注】:無(wú)需動(dòng)腦
      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. 【個(gè)人備注】:官網(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:海灘上有一堆桃子,五只猴子來(lái)分。
      1157. 第一只猴子把這堆桃子平均分為五份,多了一個(gè),
      1158. 這只猴子把多的一個(gè)扔入海中,拿走了一份。
      1159. 第二只猴子把剩下的桃子又平均分成五份,又多了一個(gè),
      1160. 它同樣把多的一個(gè)扔入海中,拿走了一份,
      1161. 第三、第四、第五只猴子都是這樣做的,
      1162. 問(wèn)海灘上原來(lái)最少有多少個(gè)桃子?
      1163. '''
      1164. def tm080():
      1165. '''
      1166. 【個(gè)人備注】:不考慮解方程什么的,問(wèn)題實(shí)際上歸結(jié)成
      1167. “整數(shù)n,迭代5次之每次都能得到整數(shù),求n的最小值”問(wèn)題。
      1168. 一開(kāi)始想簡(jiǎn)單了,以為最后的猴子只拿一個(gè),代進(jìn)去一算發(fā)現(xiàn)不是整數(shù)。
      1169. 于是直接暴力輸入,一個(gè)個(gè)試直到3121,得到整除。
      1170. 當(dāng)然也可以反著試,假設(shè)最后一個(gè)猴子拿到n個(gè)桃子,remain = lambda t:t/4*5+1,
      1171. 一個(gè)個(gè)試直到1020,得到整除,也能得出結(jié)論,最開(kāi)始的猴子拿了3121個(gè)桃子。
      1172. '''
      1173. for total in range(10000):
      1174. t = total # 沙灘上有t個(gè)桃子
      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ù),說(shuō)明不符合題意
      1179. else:
      1180. print(total,t) # 5次都能得到整數(shù),第一個(gè)猴子3121,五個(gè)猴子拿完沙灘剩余1020個(gè)。
      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,因?yàn)?*x<100,所以x<13。
      1190. 實(shí)際上因?yàn)?*x>100,得到x>11,很明顯x就是12,題意給的過(guò)于充分了。
      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. 【個(gè)人備注】:知道了這些,你就可以隨意轉(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ù)個(gè)數(shù)。
      1215. '''
      1216. def tm083():
      1217. '''
      1218. 【個(gè)人備注】:沒(méi)說(shuō)組成幾位數(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)) # 長(zhǎng)度1-8左右排列
      1226. l = list(map(lambda x:int(''.join(x)),a)) # 整理成數(shù)字形式(避免出現(xiàn)02這種情況,02實(shí)際上就是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. 【個(gè)人備注】: 因?yàn)橐膊恢缹?duì)錯(cuò),又用窮舉法驗(yàn)證驗(yàn)證了一下
      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ù)字去重,如果去重后和去重前長(zhǎng)度一致,說(shuō)明數(shù)字沒(méi)有重復(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萬(wàn)個(gè)輸出一下結(jié)果,避免程序卡死發(fā)現(xiàn)不了。
      1246. print(count) # 公司電腦比較差勁,跑了2分鐘多,也出結(jié)果了46972。
      1247. '''
      1248. 題目084:連接字符串。
      1249. '''
      1250. def tm084():
      1251. '''
      1252. 【個(gè)人備注】: join的用法,之前都已經(jīng)用過(guò)很多次了
      1253. '''
      1254. pass
      1255. '''
      1256. 題目085:輸入一個(gè)奇數(shù),然后判斷最少幾個(gè) 9 除于該數(shù)的結(jié)果為整數(shù)。
      1257. '''
      1258. def tm085():
      1259. '''
      1260. 【個(gè)人備注】:挨個(gè)試直到整除為止即可。
      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:兩個(gè)字符串連接程序。
      1271. '''
      1272. def tm086():
      1273. # 直接‘+’就行
      1274. pass
      1275. '''
      1276. 題目087:回答結(jié)果(結(jié)構(gòu)體變量傳遞)。
      1277. '''
      1278. def tm087():
      1279. '''
      1280. 沒(méi)題目沒(méi)得做
      1281. '''
      1282. pass
      1283. '''
      1284. 題目088:讀取7個(gè)數(shù)(1—50)的整數(shù)值,每讀取一個(gè)值,程序打印出該值個(gè)數(shù)的*。
      1285. '''
      1286. def tm088():
      1287. # 沒(méi)啥說(shuō)的
      1288. for i in [1,4,5,14,22]:
      1289. print('*'*i)
      1290. '''
      1291. 題目089:某個(gè)公司采用公用電話傳遞數(shù)據(jù),數(shù)據(jù)是四位的整數(shù),
      1292. 在傳遞過(guò)程中是加密的,加密規(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:列表使用實(shí)例。
      1302. '''
      1303. def tm090():
      1304. # 沒(méi)有具體要求
      1305. pass
      1306. '''
      1307. 題目091:時(shí)間函數(shù)舉例1。
      1308. 題目092:時(shí)間函數(shù)舉例2。
      1309. 題目093:時(shí)間函數(shù)舉例3。
      1310. 題目095:字符串日期轉(zhuǎn)換為易讀的日期格式。
      1311. '''
      1312. def tm091(): #tm092、tm093、tm095
      1313. # 參看tm016
      1314. pass
      1315. '''
      1316. 題目094:時(shí)間函數(shù)舉例4,一個(gè)猜數(shù)游戲,判斷一個(gè)人反應(yīng)快慢。
      1317. '''
      1318. def tm094():
      1319. import time,random
      1320. print('《猜大小0-1000之間》')
      1321. x = random.randint(0,1000)
      1322. flag = input('是否開(kāi)始(y/n):')
      1323. if flag=='y':
      1324. s = time.time()
      1325. while 1:
      1326. m = int(input('請(qǐng)輸入數(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('耗時(shí)%.2f秒'%(e-s))
      1336. print(time.sleep(5))
      1337. '''
      1338. 題目096:計(jì)算字符串中子串出現(xiàn)的次數(shù)。
      1339. '''
      1340. def tm096():
      1341. '''
      1342. 【個(gè)人備注】:用count就行了
      1343. '''
      1344. x = 'ababaabbaaa'
      1345. print(x.count('ab'))
      1346. '''
      1347. 題目097:從鍵盤輸入一些字符,逐個(gè)把它們寫(xiě)到磁盤文件上,直到輸入一個(gè) # 為止。
      1348. '''
      1349. def tm097():
      1350. '''
      1351. 【個(gè)人備注】:保存文件的方法,記住即可。
      1352. with .. as ..打開(kāi)會(huì)自動(dòng)關(guān)閉。
      1353. 其他方式打開(kāi),別忘了通過(guò)代碼關(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:從鍵盤輸入一個(gè)字符串,將小寫(xiě)字母全部轉(zhuǎn)換成大寫(xiě)字母,然后輸出到一個(gè)磁盤文件'test'中保存。
      1365. '''
      1366. def tm098():
      1367. '''
      1368. 【個(gè)人備注】:字符串大寫(xiě)
      1369. '''
      1370. c = input()
      1371. c = c.upper()
      1372. with open('d:/test.txt','w+') as f:f.write(c)
      1373. '''
      1374. 題目099:有兩個(gè)磁盤文件A和B,各存放一行字母,要求把這兩個(gè)文件中的信息合并(按字母順序排列), 輸出到一個(gè)新文件C中。
      1375. '''
      1376. def tm099():
      1377. '''
      1378. 【個(gè)人備注】:讀寫(xiě)文件
      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. 【個(gè)人備注】:終于最后一題完事~,沒(méi)啥說(shuō)的。
      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ù)更簡(jiǎn)單
      1398. l = ['ak17','b51','b52','#64']
      1399. print(dict(zip(range(4),l)))
      1400. # 得到:{0: 'ak17', 1: 'b51', 2: 'b52', 3: '#64'}

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

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多