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)。

主站蜘蛛池模板: 黄色网站不卡无码| 一级在线毛片| 欧美丝袜高跟鞋一区二区| 亚洲中文字幕在线一区播放| www成人国产在线观看网站| 亚洲国产天堂久久综合226114| 日韩精品成人在线| 国产在线拍偷自揄拍精品| 久久国产成人精品国产成人亚洲| 国产成人综合亚洲欧美在| 国产sm重味一区二区三区| 2021国产精品自产拍在线| 亚洲国产精品不卡在线| 亚洲色大成网站www国产| 午夜高清国产拍精品| 首页亚洲国产丝袜长腿综合| 国产成人高清精品免费| 久无码久无码av无码| 青青网在线国产| 美女无遮挡免费视频网站| 午夜不卡视频| 玖玖免费视频在线观看| 日韩高清成人| 2022国产无码在线| 四虎国产永久在线观看| 国产h视频免费观看| 欧美国产日韩在线播放| 一区二区三区成人| 91色综合综合热五月激情| 日韩高清在线观看不卡一区二区| 国产无码网站在线观看| 亚洲第一极品精品无码| 久久久波多野结衣av一区二区| 东京热高清无码精品| 亚洲美女高潮久久久久久久| 99精品国产电影| 91久久偷偷做嫩草影院精品| 国产成人精品一区二区不卡 | 中文字幕66页| 最新国产精品鲁鲁免费视频| 国产成人福利在线视老湿机| 色亚洲成人| 人与鲁专区| 亚洲五月激情网| 亚洲乱码视频| 好紧太爽了视频免费无码| 久久国语对白| 88av在线播放| 女人一级毛片| 国产91精品久久| 思思热精品在线8| 狠狠亚洲婷婷综合色香| 久久精品娱乐亚洲领先| 中文无码精品A∨在线观看不卡| 好吊妞欧美视频免费| 91小视频在线观看| 欧美一区中文字幕| 人妻精品久久无码区| 免费不卡视频| 国产小视频a在线观看| 日本一区中文字幕最新在线| 美女一区二区在线观看| 九九热视频在线免费观看| www亚洲精品| 亚洲视频色图| 亚洲高清无码久久久| 日韩毛片基地| 日韩在线播放中文字幕| 人妻丰满熟妇αv无码| 亚洲欧洲日韩综合| 国产乱人伦精品一区二区| 国产在线91在线电影| 国产高清免费午夜在线视频| 国产成人欧美| 在线亚洲小视频| 中文字幕 91| 日本精品中文字幕在线不卡| 免费看a级毛片| 色有码无码视频| 免费国产一级 片内射老| 国产美女精品人人做人人爽| 国产国产人免费视频成18|