1:找出字符串s='aaabbbccceeefff111144444'中,字符出現(xiàn)次數(shù)最多的字符(1)考慮去重,首先將字符串進(jìn)行過濾去重,這樣在根據(jù)這些字符進(jìn)行循環(huán)查詢時,將會減少循環(huán)次數(shù),提升效率。但是本人寫的代碼較為臃腫,有更好的希望留言評論 str = 'a1fsfs111bbbcccccvvvvvnnnnboooooosssnb' def countvalue(self, str1): :param str1: 對傳進(jìn)來的字符串過濾 :return: 返回一個不含重復(fù)字符的list 對已經(jīng)去重的list進(jìn)行遍歷,因已去重 從而減少循環(huán)次數(shù),提高檢索效率 list = Countvalue().countvalue(str1) if __name__ == '__main__': print(Countvalue().count(str))
(2)不考慮去重 if s.count(i) > max_times: elif s.count(i) == max_times:
以下內(nèi)容摘抄自:https://blog.csdn.net/watfe/article/details/79206165 http://www.runoob.com/python/python-100-examples.html 題目001:有四個數(shù)字:1、2、3、4,能組成多少個互不相同且無重復(fù)數(shù)字的三位數(shù)?各是多少? if i!=j and j!=k and i!=k and num not in arr:# 互不相同且無重復(fù)數(shù)字的三位數(shù) 【個人備注】:其實python自帶排列組合模塊,可以直接調(diào)用。 也知道這個寫法,只是函數(shù)記不住,還是百度一下才能寫出來。 如果這是面試題,能寫出后一種當(dāng)然好,不能的話還是老老實實的按照上面的思路來吧。 temp_arr = list(itertools.permutations([1, 2, 3, 4], 3)) # 排列 # A_4^3 = (4)!/(4-3)! = (4*3*2*1)/1 = 24 arr = [100*t[0]+10*t[1]+t[2] for t in temp_arr] 題目002:企業(yè)發(fā)放的獎金根據(jù)利潤(I)的多少來提成: 利潤高于10萬元,低于20萬元時,低于10萬元的部分按10%提成,高于10萬元的部分,可提成7.5%; 20萬到40萬之間時,高于20萬元的部分,可提成5%; 40萬到60萬之間時高于40萬元的部分,可提成3%; 60萬到100萬之間時,高于60萬元的部分,可提成1.5%; 高于100萬元時,超過100萬元的部分按1%提成。 從鍵盤輸入當(dāng)月利潤I,求應(yīng)發(fā)放獎金總數(shù)? 【個人備注】:這種處理數(shù)軸問題的寫法,值得參考。比elif的寫法,簡潔方便的多。 money = int(input('凈利潤:')) arr = [1000000,600000,400000,200000,100000,0] rat = [0.01,0.015,0.03,0.05,0.075,0.1] for i in range(len(arr)): if money>arr[i]: # 對于處于區(qū)間的部分 bonus+=(money-arr[i])*rat[i] # 計算并累加獎勵 題目003:一個整數(shù),它加上100后是一個完全平方數(shù),再加上168又是一個完全平方數(shù),請問該數(shù)是多少? 【個人備注】:網(wǎng)站上是求了一下方程,沒細(xì)看。 python又不是沒有開方函數(shù),直接按字面意思解了。 題目004:輸入某年某月某日,判斷這一天是這一年的第幾天? 【個人備注】:知道python有時間元組這一概念,這道題完全不需要計算。 tm_yday 第幾天(1~366, 366是儒略歷) date = input('輸入時間(例如2018-01-23):') st = time.strptime(date,'%Y-%m-%d') # 時間文本轉(zhuǎn)化成時間元祖 題目005:輸入三個整數(shù)x,y,z,請把這三個數(shù)由小到大輸出。 x = input('輸入第1個數(shù)字:') y = input('輸入第2個數(shù)字:') z = input('輸入第3個數(shù)字:') arr = sorted(l) # 你也可以使用list.sort()方法來排序,此時list本身將被修改 程序分析:斐波那契數(shù)列,又稱黃金分割數(shù)列,指的是這樣一個數(shù)列:0、1、1、2、3、5、8、13、21、34、……。 【個人備注】:很多種解法,我是按照分割的方式,每次取列表后兩項,然后相加。 題目007:將一個列表的數(shù)據(jù)復(fù)制到另一個列表中。 【個人備注】:如果系統(tǒng)的看過python教程之類的應(yīng)該都知道。 Python里面一切都是對象,list的復(fù)制需要用[:]的方式。 至于b=a只是相當(dāng)于給a取了個別名而已,指向的是同一個列表,并沒有實現(xiàn)復(fù)制。 print(id(a),id(b)) # 可以看到a,b的內(nèi)存不一致,是復(fù)制 print(id(a),id(b)) # 如果去掉[:],可以看到a,b的內(nèi)存一致,并沒有復(fù)制,指向的是同一個列表 【個人備注】:已經(jīng)忘了,百度了才想起來口訣表具體長什么樣。 注意 %-7s 和 end='' 的用法,其他沒什么。 string = '%d*%d=%d'%(j,i,j*i) print('%-7s'%string,end='') csdn用戶isgoto用format方法生成字符串,也可以參考。 用循環(huán)到i+1的方法,比上面還能少寫一行。 for j in range(1, i + 1): print('{0} * {1} = {2}'.format(i, j, i * j),end='\t') 【個人備注】:time.sleep(),用過的都知道。 題目010:暫停一秒輸出,并格式化當(dāng)前時間。 a = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.localtime()時間戳轉(zhuǎn)化成時間元祖 b = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) # time.strftime()時間元祖轉(zhuǎn)化成時間文本 【個人備注】:理清思路是關(guān)鍵,理解成滿兩個月后,每月都能生兔子,就好辦了。 print(i,mm+m1+m2) # 每個月有多少對兔子 題目012:判斷101-200之間有多少個素數(shù),并輸出所有素數(shù)。 【個人備注】:按照素數(shù)不能被之前的素數(shù)整除,取200以內(nèi)所有素數(shù),然后取出101-200之間的部分。 # else: # 這是一開始我自己的寫法,后來發(fā)現(xiàn)for可以直接接else子語句 else: # 迭代的對象成功迭代完,位于else的子句將執(zhí)行;而如果在for循環(huán)中含有break時則直接終止循環(huán),并不會執(zhí)行else子句。 for i in range(len(arr)): 所謂'水仙花數(shù)'是指一個三位數(shù),其各位數(shù)字立方和等于該數(shù)本身。 例如:153是一個'水仙花數(shù)',因為153=1的三次方+5的三次方+3的三次方。 【個人備注】: // 取整,% 求余,**3 三次方。知道取整求余寫法的就沒問題。 for i in range(100,1000): 題目014:將一個正整數(shù)分解質(zhì)因數(shù)。例如:輸入90,打印出90=2*3*3*5。 num = int(input('輸入一個整數(shù):')) for i in range(2,int(math.sqrt(num))+1): # 因為題目是一個沒寫范圍正整數(shù),開方可以有效減少該值過大時候的計算量 題目015:利用條件運算符的嵌套來完成此題:學(xué)習(xí)成績>=90分的同學(xué)用A表示,60-89分之間的用B表示,60分以下的用C表示。 score = float(input('輸入一個成績:')) 【個人備注】:用的不多經(jīng)常忘,整理了一下參考答案和一些轉(zhuǎn)換 《Python3 日期文本互轉(zhuǎn),時間戳,時間差 以及 時區(qū)變換》 https://blog.csdn.net/watfe/article/details/84943732 print(time.time()) # 時間戳 1498539133.655 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 print(time.asctime()) # 時間的一種可讀文本形式 'Tue Jun 27 12:53:50 2017' print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())) # 按指定文本格式輸出時間 '2017-06-27 13:00:57' st = time.localtime(time.time()) # 時間戳 轉(zhuǎn)化成 時間元祖 st = time.strptime('2018/1/23','%Y/%m/%d') # 時間文本 轉(zhuǎn)化成 時間元祖 date = time.strftime('%Y-%m-%d',st) # 時間元祖 轉(zhuǎn)化成 時間文本 '%Y-%m-%d %H:%M:%S' print(date) # 前面兩條函數(shù)配合著用,相當(dāng)于將時間文本重新格式化。 # 另外我們可以通過datetime模塊來計算時間差,例如: dt1 = datetime.datetime.fromtimestamp(1517302458) dt2 = datetime.datetime.now() print('相差%d天零%.1f個小時'%((dt2-dt1).days,(dt2-dt1).seconds/60/60)) 2018-01-30 16:54:18 <class 'datetime.datetime'> 2018-02-01 16:27:47.524774 # 注意上面的日期雖然看起來是文本,但實際上是datetime類型的。 # 可以通過時間戳/時間文本轉(zhuǎn)換得到,然后才能進(jìn)行日期時間計算。 d1 = datetime.datetime.strptime('2017-10-16 19:21:22', '%Y-%m-%d %H:%M:%S') 題目017:輸入一行字符,分別統(tǒng)計出其中英文字母、空格、數(shù)字和其它字符的個數(shù)。 if c in string.ascii_letters: # abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ if c in string.digits: # 0123456789 看了參考答案才知道有現(xiàn)成的函數(shù)可以用。 其實隨便哪種都行,甚至直接把一串字母粘上去看起來更直接。 s = input('input a string:\n') letters,space,digit,others = 0,0,0,0 print('char = %d,space = %d,digit = %d,others = %d' % (letters,space,digit,others)) 題目018:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一個數(shù)字。例如2+22+222+2222+22222(此時共有5個數(shù)相加),幾個數(shù)相加由鍵盤控制。 【個人備注】:答案給的解法很多種,但是我還是認(rèn)為我寫的方法最簡單。 20000 + 2*2000 + 3*200 + 4*20 + 5*2 1*2*10^4 + 2*2*10^3 + 3*2*10^2 + 4*2*10^1 + 5*2*10^0 題目019:一個數(shù)如果恰好等于它的因子之和,這個數(shù)就稱為'完數(shù)'。例如6=1+2+3.編程找出1000以內(nèi)的所有完數(shù)。 【個人備注】:題意看的不是太懂,于是百度了一下:完數(shù)就是除了自身之外的所有約數(shù)之和等于他本身。 第一個完全數(shù)是6,它有約數(shù)1、2、3、6,除去它本身6外,其余3個數(shù)相加,1+2+3=6。 第二個完全數(shù)是28,它有約數(shù)1、2、4、7、14、28,除去它本身28外,其余5個數(shù)相加,1+2+4+7+14=28。 先求出所有約數(shù),然后求和比一下是否相等就行了,沒有難度 for num in range(1,1000): 題目020:一球從100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地時,共經(jīng)過多少米?第10次反彈多高? m = 100 # 第一次落地,經(jīng)過了一百米 for i in range(10-1): # 之后9次彈起到落地 total += 2*m # 彈起然后重新落地,一共經(jīng)過的距離 猴子第一天摘下若干個桃子,當(dāng)即吃了一半,還不癮,又多吃了一個 【個人備注】:第十天num=1個,第九天必然是4個:4/2-1=1,也就是(num+1)*2=4。 做這種題,先用算數(shù)式列出來,然后用代碼描述就行了。 題目022:兩個乒乓球隊進(jìn)行比賽,各出三人。 a說他不和x比,c說他不和x,z比,請編程序找出三隊賽手的名單。 【個人備注】:關(guān)鍵是將抽象化,將問題抽象成代碼方式。 我的解題思路,是用排列組合函數(shù),列出方案,然后排除。 而官方解答里面有一個純粹的for循環(huán)加if的求解方式, 更抽象一些,用了一個很常用固定范式,直接拿來解題了。 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')] 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']] elif 'cx' in i or 'cz' in i: print(i) # 得到 ['az', 'bx', 'cy'] for a in ['x','y','z']: # a在x,y,z中挑一個打 for b in ['x', 'y', 'z']: # b在x,y,z中挑一個打 for c in ['x', 'y', 'z']: # c在x,y,z中挑一個打 三層總計27種打法 if a!=b and b!=c and c!=a: # a,b,c不能挑同一個人 縮減到6種打法 if a!='x' and c!='x' and c!='z': # 依據(jù)題意不能ax,cx,cz 縮減到1種打法 然后將[0,1,2,3,4,5,6]變成了[3,2,1,0,1,2,3],也就是每行左邊空格數(shù)。 print(' '*blank+'*'*(num-2*blank)+' '*blank) 題目024:有一分?jǐn)?shù)序列:2/1,3/2,5/3,8/5,13/8,21/13...求出這個數(shù)列的前20項之和。 題目025:求1+2!+3!+...+20!的和。 【個人備注】:按題目要求,公式f(n)=n*f(n-1),遞歸調(diào)用求解。 題目027:利用遞歸函數(shù)調(diào)用方式,將所輸入的5個字符,以相反順序打印出來。 【個人備注】:直接從官網(wǎng)復(fù)制,不喜歡遞歸。 s = input('Input a string:') 【個人備注】:官網(wǎng)給的還是遞歸方法,因為不用遞歸的話就是個口算題。 題目029:給一個不多于5位的正整數(shù),要求:一、求它是幾位數(shù),二、逆序打印出各位數(shù)字。 題目030:一個5位數(shù),判斷它是不是回文數(shù)。即12321是回文數(shù),個位與萬位相同,十位與千位相同。 for i in range(len(s)//2): 題目031:請輸入星期幾的第一個字母來判斷一下是星期幾,如果第一個字母一樣,則繼續(xù)判斷第二個字母。 week = ['monday','tuesday','wednesday','thursday','friday','saturday','sunday'] inp = inp+input('請輸入一個字母:') for day in week: # 挑出滿足輸入的星期 if len(arr)==1: # 只剩一個,說明唯一,可以輸出結(jié)果 print('以%s開頭的單詞是:%s'%(inp,arr[0])) elif len(arr)==0: # 一個都沒有說明輸錯了,需要重新輸入 【個人備注】:一開始沒看懂題目項干啥,直接print(list)不就是逗號分隔么 a = ['1','2','3','4','5'] 題目034:練習(xí)函數(shù)調(diào)用。 【個人備注】:沒頭沒尾的一個題,之前的遞歸實際上就是函數(shù)的調(diào)用了。不寫了。 題目036:求100之內(nèi)的素數(shù)。 【個人備注】:素數(shù)就是質(zhì)數(shù) 題目037:對10個數(shù)進(jìn)行排序。 【個人備注】:實際上考察的是排序。揣測了一下題意,寫了兩種解法 a = [1,5,7,3,2,4,9,10,6,8] a = [1,5,7,3,2,4,9,10,6,8] 【個人備注】:思路比較簡單,n*n的矩陣都可以用這個求解。 a = [[1,2,3],[4,5,6],[7,8,9]] for i in range(n): # 左上到右下一條線 for i in range(n): # 右上到左下一條線 if n%2==1: # 如果是奇數(shù),刪掉重復(fù)計算的中間點 題目039:有一個已經(jīng)排好序的數(shù)組?,F(xiàn)輸入一個數(shù),要求按原來的規(guī)律將它插入數(shù)組中。 aaa = [1,5,8,14,28,39,60,89,134,324,612,900] aaa.insert(aaa.index(a),b) 【個人備注】:不是很清楚什么意思,直接看了官網(wǎng)的解答。 如果是函數(shù)中的局部變量,每次調(diào)用函數(shù)都會初始化。 而類中的變量,創(chuàng)建類的時候初始化,每次執(zhí)行類中的函數(shù)的時候,不會初始化類變量。 if __name__ == '__main__': # StaticVar作為類的一個屬性,相當(dāng)于靜態(tài)變量 題目042:學(xué)習(xí)使用auto定義變量的用法。 【個人備注】:同樣沒看懂題意,看了下官網(wǎng)答案 發(fā)現(xiàn)實際是想說變量作用域, python是有分局部變量、全局變量的等區(qū)分的。 print('internal block num = %d'%num) print('The num = %d'%num) 題目043:模仿靜態(tài)變量(static)另一案例。 【個人備注】:官網(wǎng)的答案和041沒啥區(qū)別,又來一遍 題目044:兩個3*3的矩陣,實現(xiàn)其對應(yīng)位置的數(shù)據(jù)相加,并返回一個新矩陣: 【個人備注】:自己寫了一個,但是印象里python是有矩陣計算工具的。 官網(wǎng)就有人用該工具numpy寫了一下,很簡潔。 x = [[12,7,3],[4,5,6],[7,8,9]] y = [[5,8,1],[6,7,3],[4,5,9]] import numpy # pip install numpy 需要安裝模塊 x = numpy.array([[12,7,3],[4,5,6],[7,8,9]]) y = numpy.array([[5,8,1],[6,7,3],[4,5,9]]) 題目045:統(tǒng)計 1 到 100 之和。 【個人備注】:簡單,但官網(wǎng)有人寫的更簡單 題目046:求輸入數(shù)字的平方,如果平方運算后小于 50 則退出。 x= input('輸入數(shù)字得到平方值:') 【個人備注】:看了一眼官網(wǎng)答案,簡單到懶得寫。以下官網(wǎng)答案。 print('%d 大于 %d' % (i,j)) print('%d 等于 %d' % (i,j)) print('%d 小于 %d' % (i,j)) 題目049:使用lambda來創(chuàng)建匿名函數(shù)。 【個人備注】:用的不多又忘了,看了一下網(wǎng)上的教程,整理了一下。 #lambda函數(shù)也叫匿名函數(shù),即,函數(shù)沒有具體的名稱。先來看一個最簡單例子: #lambda存在意義就是對簡單函數(shù)的簡潔表示。 #lambda語句中,冒號前是參數(shù),可以有多個,用逗號隔開,冒號右邊的返回值。 #常搭配內(nèi)置函數(shù)map、filter、reduce,都是應(yīng)用于序列的內(nèi)置函數(shù)。常見的序列包括list、tuple、str。 #map(func, *iterables) --> map object #filter(function or None, iterable) --> filter object #reduce(function, sequence[, initial]) -> value foo = [2, 18, 9, 22, 17, 24, 8, 12, 27] print(list(map(lambda x: x * 2 + 10, foo))) # 映射 [14, 46, 28, 54, 44, 58, 26, 34, 64] print(list(filter(lambda x: x % 3 == 0, foo))) # 過濾 [18, 9, 24, 12, 27] from functools import reduce # 在Python 3里,reduce()函數(shù)已經(jīng)被從全局名字空間里移除了,它現(xiàn)在被放置在fucntools模塊里 print(reduce(lambda x, y: x + y, foo)) # 累積 139 【個人備注】:之前學(xué)習(xí)隨機(jī)的時候整理的東西,用到時候來找就行了 random.random() # 0.85415370477785668 # 隨機(jī)一個[0,1)之間的浮點數(shù) random.uniform(0, 100) # 18.7356606526 # 隨機(jī)一個[0,100]之間的浮點數(shù) random.randrange(0, 100, 2) # 44 # 隨機(jī)一個[0,100)之間的偶數(shù) random.randint(0, 100) # 22 # 隨機(jī)一個[0,100]之間的整數(shù) seed = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+=-' # 任意字符串(作為隨機(jī)字符種子庫) random.choice(seed) # 'd' # 隨機(jī)一個字符 random.sample(seed, 3) # ['a', 'd', 'b'] # 隨機(jī)多個字符(字符可重復(fù)) ''.join(random.sample(seed,3)) # '^f^' # 隨機(jī)指定長度字符串(字符可重復(fù)) random.shuffle(list) # 列表中的元素打亂 def tm051(): # tm052 # tm053 # tm055 【個人備注】:大概看了一下資料,按位操作可以通過bin()函數(shù)轉(zhuǎn)換為二進(jìn)制從而實現(xiàn)。 感覺二進(jìn)制的計算如果不是學(xué)加密之類的基本用不上。 所以這一題,大概寫了集合的用法,&、|在python中是集合set()才用的符號 兩個列表求交集并集,通常也都是轉(zhuǎn)換為集合,然后進(jìn)行計算的。 print(x, y) # 重復(fù)的被刪除 {'n', 'o', 'b', 'u', 'r'} {'o', 'g', 'e', 'l'} print(x | y) # 并集 {'e', 'o', 'g', 'l', 'u', 'n', 'b', 'r'} print(x - y) # 差集 {'n', 'b', 'u', 'r'} # 當(dāng)然也可以寫成函數(shù)形式,不過確實沒有上面符號好記。 題目054:取一個整數(shù)a從右端開始的4-7位。 print(b[-7:-3]) # 寫的時候注意一下python切片是[-7:-4)左閉右開的,不包含[-4]的,所以要寫成-3才能取到 題目056:畫圖,學(xué)用circle畫圓形。 題目058:畫圖,學(xué)用rectangle畫方形。 題目064:利用ellipse 和 rectangle 畫圖。 題目065:一個最優(yōu)美的圖案?!?/span> 所有畫圖題pass 有愛的自己參照下面,將官網(wǎng)答案改成python3運行即可。 def tm056(): # tm057、tm058、tm059、tm063、tm064、tm065、 復(fù)制了官網(wǎng)Python2答案,調(diào)整一下放到python3上成功運行了。 canvas = tkinter.Canvas(width=600, height=500, bg='yellow') canvas.pack(expand='yes', fill='both') canvas.create_oval(300 - k,250 - k,300 + k,250 + k, width=1) 題目061:打印出楊輝三角形(要求打印出10行如下圖)。 1 9 36 84 126 126 84 36 9 1 【個人備注】:感覺自己寫的比官網(wǎng)簡單好懂 while len(arr)<10: # [1,1] arr = [a[i]+b[i] for i in range(len(a))] # [1,2,1] s = [str(i) for i in arr] 題目066:輸入3個數(shù)a,b,c,按大小順序輸出。 題目067:輸入數(shù)組,最大的與第一個元素交換,最小的與最后一個元素交換,輸出數(shù)組。 【個人備注】:感覺自己寫的比官網(wǎng)簡單好懂,直接用python思維寫,確實很方便 a = [6,3,10,2,5,1,4,7,9,8] 題目068:有n個整數(shù),使其前面各數(shù)順序向后移m個位置,最后m個數(shù)變成最前面的m個數(shù) a = [1,2,3,4,5,6,7,8,9,10] 從第一個人開始報數(shù)(從1到3報數(shù)),凡報到3的人退出圈子,問最后留下的是原來第幾號的那位。 【個人備注】:python基礎(chǔ)變量沒有這種圈狀循環(huán)的。 缺點是列表刪除中間項,后面的索引值都會變,需要計算。 arr = list(range(1,n+1)) # 所有人門外站成一隊【a】,進(jìn)門后依舊按序站好【b】 while len(a+b)>1: # 循環(huán)直到只剩1人 num,count=a.pop(0),count+1 # 排隊進(jìn)門,每進(jìn)一人【a.pop】,按一下計數(shù)器 if count%3!=0:b.append(num) # 進(jìn)門后依舊按序站好【b.append】,計數(shù)器逢3淘汰。 if a==[]:a,b=b,[] # 如果門外沒人了【a=[]】,所有人重新到門外站好【a=b】 題目070:寫一個函數(shù),求一個字符串的長度,在main函數(shù)中輸入字符串,并輸出其長度。 if __name__ == '__main__': 題目071:編寫input()和output()函數(shù)輸入,輸出5個學(xué)生的數(shù)據(jù)記錄。 name = input('輸入學(xué)生姓名:') score = input('輸入學(xué)生成績:') name = input('輸入學(xué)生姓名:') print('該學(xué)生的成績是:',data.get(name)) if __name__ == '__main__': a = input('輸入/輸出學(xué)生成績(i/o):') 【個人備注】:已經(jīng)幾乎忘了鏈表了,網(wǎng)上搜了一下終于想起鏈表是什么來著。 http://www./nForum/#!article/Python/73818?p=10 【個人備注】:Σ( ° △ °|||)︴,不是我偷工減料,題目就是這個,后面太監(jiān)了 題目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 【個人備注】:學(xué)了lambda想耍一下,結(jié)果發(fā)現(xiàn)官網(wǎng)寫的比我還簡潔! fenmu = range(2,n+1,2) if n%2==0 else range(1,n+1,2) s = sum(map(lambda x:1/x,fenmu)) ls = sum([1/i for i in range(n,0,-2)]) person = {'li':18,'wang':50,'zhang':20,'sun':22} person = {'li':18,'wang':50,'zhang':20,'sun':22} 第二只猴子把剩下的桃子又平均分成五份,又多了一個, 【個人備注】:不考慮解方程什么的,問題實際上歸結(jié)成 “整數(shù)n,迭代5次之每次都能得到整數(shù),求n的最小值”問題。 一開始想簡單了,以為最后的猴子只拿一個,代進(jìn)去一算發(fā)現(xiàn)不是整數(shù)。 于是直接暴力輸入,一個個試直到3121,得到整除。 當(dāng)然也可以反著試,假設(shè)最后一個猴子拿到n個桃子,remain = lambda t:t/4*5+1, 一個個試直到1020,得到整除,也能得出結(jié)論,最開始的猴子拿了3121個桃子。 for total in range(10000): remain = lambda t:(t-1)/5*4 # 每次分桃后剩余桃子。 if t%1!=0:break # 如果不是整數(shù),說明不符合題意 print(total,t) # 5次都能得到整數(shù),第一個猴子3121,五個猴子拿完沙灘剩余1020個。 題目081:809*??=800*??+9*?? 其中??代表的兩位數(shù), 809*??為四位數(shù),8*??的結(jié)果為兩位數(shù),9*??的結(jié)果為3位數(shù)。 求??代表的兩位數(shù),及809*??后的結(jié)果。 假設(shè)??為x,因為8*x<100,所以x<13。 實際上因為9*x>100,得到x>11,很明顯x就是12,題意給的過于充分了。 if l(809*i)==4 and l(8*i)==2 and l(9*i)==3: 題目082:八進(jìn)制轉(zhuǎn)換為十進(jìn)制 【個人備注】:知道了這些,你就可以隨意轉(zhuǎn)了。 print(bin(10)) #十轉(zhuǎn)二 print(oct(10)) #十轉(zhuǎn)八 print(hex(10)) #十轉(zhuǎn)16 print(int('10',8)) #八轉(zhuǎn)十 print(int('10',2)) #二轉(zhuǎn)十 print(int('10',16)) #16轉(zhuǎn)十 題目083:求0—7所能組成的奇數(shù)個數(shù)。 【個人備注】:沒說組成幾位數(shù)或是否重復(fù)使用。假設(shè)1-8位都可以,且不能重復(fù)使用。 直接用排列函數(shù),累加然后去重,就得到答案了。 s = [i for i in '01234567'] a = list(itertools.permutations(s,i)) # 長度1-8左右排列 l = list(map(lambda x:int(''.join(x)),a)) # 整理成數(shù)字形式(避免出現(xiàn)02這種情況,02實際上就是2) arr2 = list(filter(lambda x:x%2==1,arr1)) # 只留奇數(shù) print(len(arr),len(arr1),len(arr2)) # 答案是46972 【個人備注】: 因為也不知道對錯,又用窮舉法驗證驗證了一下 for i in range(76543211): # 能組成的最大數(shù)字也就是76543210了 s = str(i) # 轉(zhuǎn)換成文本形式s if '8' in s or '9' in s: # s中不包含8和9 cs = set([c for c in s])# s中的數(shù)字去重,如果去重后和去重前長度一致,說明數(shù)字沒有重復(fù)使用 if len(s)==len(cs) and s[-1] in '1357': # 各位不重復(fù)且是奇數(shù) if i%100000==0:print(i,count) # 每10萬個輸出一下結(jié)果,避免程序卡死發(fā)現(xiàn)不了。 print(count) # 公司電腦比較差勁,跑了2分鐘多,也出結(jié)果了46972。 【個人備注】: join的用法,之前都已經(jīng)用過很多次了 題目085:輸入一個奇數(shù),然后判斷最少幾個 9 除于該數(shù)的結(jié)果為整數(shù)。 x = int(input('input a number:')) 題目087:回答結(jié)果(結(jié)構(gòu)體變量傳遞)。 題目088:讀取7個數(shù)(1—50)的整數(shù)值,每讀取一個值,程序打印出該值個數(shù)的*。 題目089:某個公司采用公用電話傳遞數(shù)據(jù),數(shù)據(jù)是四位的整數(shù), 每位數(shù)字都加上5,然后用和除以10的余數(shù)代替該數(shù)字,再將第一位和第四位交換,第二位和第三位交換。 q,b,s,g = x//1000,x//100%10,x//10%10,x%10 s = (g+c)%10*1000+(s+c)%10*100+(b+c)%10*10+(q+c)%10 題目095:字符串日期轉(zhuǎn)換為易讀的日期格式。 def tm091(): #tm092、tm093、tm095 題目094:時間函數(shù)舉例4,一個猜數(shù)游戲,判斷一個人反應(yīng)快慢。 x = random.randint(0,1000) flag = input('是否開始(y/n):') m = int(input('請輸入數(shù)字:')) 題目096:計算字符串中子串出現(xiàn)的次數(shù)。 題目097:從鍵盤輸入一些字符,逐個把它們寫到磁盤文件上,直到輸入一個 # 為止。 with .. as ..打開會自動關(guān)閉。 with open(path,'w+') as f:f.write('') with open(path,'a+') as f:f.write(c) 題目098:從鍵盤輸入一個字符串,將小寫字母全部轉(zhuǎn)換成大寫字母,然后輸出到一個磁盤文件'test'中保存。 with open('d:/test.txt','w+') as f:f.write(c) 題目099:有兩個磁盤文件A和B,各存放一行字母,要求把這兩個文件中的信息合并(按字母順序排列), 輸出到一個新文件C中。 with open('d:/a.txt','r+') as f:a=f.read() with open('d:/b.txt','r+') as f:b=f.read() with open('d:/c.txt','w+') as f:f.write(a+b) l = ['ak17','b51','b52','#64'] # 得到:{0: 'ak17', 1: 'b51', 2: 'b52', 3: '#64'} l = ['ak17','b51','b52','#64'] print(dict(zip(range(4),l))) # 得到:{0: 'ak17', 1: 'b51', 2: 'b52', 3: '#64'}
|