999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

一道奧賽Python題的四種解法

2021-10-15 16:43:45牟曉東
電腦報 2021年24期

牟曉東

請用1-6六個數字組成一個六位數abcdef.其中不同的字母代表1-6中不同的數字,要求:ab是2的倍數.abc是3的倍數.abcd能被4整除.abcde能被5整除.abcdef是6的倍數

請問:這樣的六位數有幾個?各是多少?

解法1:借助字符串求解

借助字符串方法通過多列表求解。首先建立第一個空列表my_listl:“my_listl=¨”,通過構建循環“for l in range(123456,654321):”控制從最小數123456到最大數654321依次遍歷,同時根據題意進行第一次數據過濾:“if int (i//10000)%2==0 andint

(i//1000)% 3==0 and int( 111100)%4==0 andint(i//10)%5==0 andi%6==0”,即從該數中分別取出高二位ab、高三位abc……對2、3等進行整除判斷,如果五個條件同時滿足的話,則將該整型數據轉換為字符串后追加至my_listl中:“my_listl.append(str(1))”。

接著建立第二個空列表my_list2,通過構建循環“for words in my_listl:“對剛剛得到的列表my_listl進行遍歷,第二次數據過濾的條件是“if '0'not in words and '7' not in words and '8' not inwords and '9' not in words:”,即去除其中包含有非“123456”字符(0、7、8、9)的“不合法”數據,將滿足要求的數據再次通過append方法追加至列表my_list2中:“my_list2append( words)”。

再建立第三個空列表my_list3,對列表my_list2進行遍歷:“for words in my_list2:”,將每個數據依次保存至集合my_set中:“my_set= set

此時,在列表my_list3中所保存的數據已經是符合要求的數據了,但其類型是字符串而非真正的整型數據,因此再建立第四個列表my_list4,通過“forwords in my_list3:”對列表my_list3進行遍歷,將各數據通過int()函數轉換為整型數據后追加至列表my_list4中:“my_list4.append(int(words》”。

最后,使用一條print()語句將結果輸出:“print(‘這樣的六位數有,len( my_list4),‘個,,‘它們是:,my_list4)”。

運行程序,得到最終運算結果:

“這樣的六位數有2個,它們是:[123654,321654]"<如圖1)。

在Spyder編輯器右上方的“變量管理器”中也不難發現,程序在一步一步運行時的四個列表中的數據變化,從最開始的my_listl有707個數據,然后是my_list2已經被“過濾”、只保留50個數據,而最終的my_list3和my_list4則只有兩個符合題意要求的數據。

解法2:利用集合“去重”

借助取整除與取余求各數位,再進行范圍限定和集合“去重”。首先建立空列表my_list,同樣是先進行五個整除條件的第一次數據過濾操作,范圍仍然是從123456至654321:將符合條件的數據追加至列表my_list中:“my_list.append(i)”。

接著對列表my_list進行數據遍歷:“for num inmy_list”,利用Python中的數學取整除運算“//t和取余運算“%”,再結合int()取整函數,分別取出每個六位數的各數位,從高位到低位依次賦值給a、b、c、d、e和f六個變量;然后進行判斷:“if O

運行程序,得到最終運算結果:“123654和321654”(如圖2)。

解法3:多層循環嵌套

先層層循環嵌套確保各數位相異再進行整除過濾。首先建立空列表my_list,從最高位a進行層層循環嵌套:“for a in range(l,7)”,控制每個數位從最小數1至最大數6遞增;接著進入下一層循環,構建次高位b:“for b iniange(1,7)”,此時要與它的上一層循環(高位a)進行是否相異的判斷:“ifb! =a:”,該條件成立的話才繼續進入下一層循環:“for c iniange(1,7)”,同樣要進行三個變量的兩兩相異判斷,由于上層已經進行了a、b判斷,因此只進行c與a、c與b的相異判斷:“if c! =a and c! =b”;按照這個規律一直向內循環,一直進行到最低位變量f,f要與它的外層循環變量e、d、c、b和a都相異:“if!=a and f!=bandf! =candf! =dandf! =e”,條件均滿足的話,構建符合條件的數據保存至變量num中:“num=a*100000+b*lOOOO+c*lOOO+d*100+e*10+f”,并且將它追加至列表my_list中。

此時,已經得到了一組各數位均不相同的六位數,再對列表my_list的數據進行遍歷:“for num inmy_list”,判斷條件即為題意中的五個整除條件:“if int(num//10000)%2==0and int( num//1000)% 3==0 and int (num//100)% 4==0and int (num//10)%5==0 and num% 6==0“;符合該條件的話,直接打印輸出即可:“print( num)”。

運行程序,得到最終運算結果:“123654和321654”(如圖3)。

解法4:借助itertools迭代器模塊

借助于Python的itertools迭代器模塊可以比較方便地解決本題,本法代碼量少、技巧性較高,中學生理解起來的難度也較大。

首先導入itertools,建立一個只包含1-6六個數字的數列array:“array=【1,2,3,4,5,6]";接著建立變量pailie,其值為對數列array中的數據進行所有組合排列:“pailie= iterr,ools.permutations( array)”;此時得到的數據已經是各數位均相異的數據,不必再像上面的三種方法進行集合數據去重或條件限定的判斷;然后對變量pailie中的數據進行遍歷:“for xinpailie”,同時使用map()函數、int()函數、join方法等進行數據構建,保存至變量num中:“nuni= im(¨'.join( rnap( str,x》)”;接著,同樣是使用題意中的五個整除條件構建if語句:“if in“nurn//10000)%2==0 and int (num//1000)% 3==0 and int( num//100) %4==0 and int( num//10) %5==0 andnum%6==0“,符合該條件即為題目所求的數據,最后將變量num打印輸出即可:“print( num)”。

運行程序,同樣也是得到了最終運算結果:“123654和321654”(如圖4)。

主站蜘蛛池模板: 国产丝袜无码精品| 免费无码又爽又黄又刺激网站| 亚洲AⅤ永久无码精品毛片| 免费人成又黄又爽的视频网站| 久久久久久高潮白浆| 国产亚洲欧美日本一二三本道| 午夜无码一区二区三区| 亚洲专区一区二区在线观看| 四虎影视8848永久精品| 黄片一区二区三区| 欧美不卡在线视频| 精品少妇人妻av无码久久| 欧美国产日韩在线播放| 国产幂在线无码精品| 欧美a级在线| 日本久久久久久免费网络| 国产综合日韩另类一区二区| 99尹人香蕉国产免费天天拍| 国产系列在线| 亚洲黄色视频在线观看一区| 99激情网| 精品久久香蕉国产线看观看gif| 国产喷水视频| 97国产在线观看| 高清免费毛片| 色综合天天娱乐综合网| 一级毛片在线播放| 精品伊人久久久香线蕉| 欧美午夜网| 久久99国产综合精品1| 国产精女同一区二区三区久| 国产美女人喷水在线观看| 亚洲成人在线网| 国产美女精品一区二区| 亚洲经典在线中文字幕| 91精品人妻一区二区| 亚洲人成网站色7799在线播放| jijzzizz老师出水喷水喷出| 亚洲成人高清在线观看| 九九香蕉视频| 国产精品任我爽爆在线播放6080| 欧美亚洲国产精品久久蜜芽| 又黄又湿又爽的视频| 婷婷六月综合网| a毛片在线播放| 中文字幕天无码久久精品视频免费 | 亚洲成人在线网| 国产成人免费观看在线视频| 日本91在线| 久久久久人妻一区精品色奶水| av无码久久精品| 色精品视频| 欧美69视频在线| 亚洲日韩高清无码| 成人中文在线| 久久综合丝袜长腿丝袜| 欧美综合一区二区三区| 国产综合日韩另类一区二区| 九色综合视频网| 亚洲中文无码av永久伊人| 日韩第一页在线| 国产不卡在线看| 亚洲国产精品日韩专区AV| 99人妻碰碰碰久久久久禁片| 国产日韩欧美精品区性色| 亚洲最猛黑人xxxx黑人猛交| 98超碰在线观看| 亚洲综合在线最大成人| 四虎精品国产AV二区| 国产极品粉嫩小泬免费看| 欧美成a人片在线观看| 免费国产黄线在线观看| 欧美日本激情| 无码网站免费观看| 久久久受www免费人成| 日本午夜影院| 激情六月丁香婷婷四房播| 中文字幕佐山爱一区二区免费| 亚洲激情99| 色婷婷狠狠干| 五月婷婷丁香综合| 日韩无码真实干出血视频|