欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用Python實(shí)現(xiàn)外觀數(shù)列求解

 更新時(shí)間:2022年03月29日 08:53:38   作者:趙卓不凡  
這篇文章主要介紹了利用Python實(shí)現(xiàn)外觀數(shù)列求解,文章利用舉例說明文章的主題內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴樂意參考一下

1. 引言

事情的由來是這樣的,今天遇到一個(gè)非常有意思的題目,如下:

1–11–21–1211–111221–312211

觀察上述數(shù)字,找出其中的規(guī)律,并嘗試思考給出下一個(gè)數(shù)字?
哇偶,可以先仔細(xì)思考一下下。。。

2. 外觀數(shù)列

外觀數(shù)列是一個(gè)整數(shù)序列,從數(shù)字 1 開始,序列中的每一項(xiàng)都是對(duì)前一項(xiàng)的描述。

前五項(xiàng)如下:

1. ? ? 1
2. ? ? 11
3. ? ? 21
4. ? ? 1211
5. ? ? 111221
1 被讀作 ?"one 1" ?("一個(gè)一") , 即 11。
11 被讀作 "two 1s" ("兩個(gè)一"), 即 21。
21 被讀作 "one 2", ?"one 1" ("一個(gè)二" , ?"一個(gè)一") , 即 1211。
依次類推。。>>>[key for key, group in groupby('AAAABBBCCDAABBB')]
[A, B, C, D, A, B]

找出規(guī)律后,我們可以很方便的知道第6項(xiàng)的數(shù)字為 312211, 第7項(xiàng)為 13112221。所以,我們可以編寫一個(gè)函數(shù),來自動(dòng)幫我們生成這個(gè)數(shù)列的某一項(xiàng)。

3. 代碼思路

經(jīng)過思考,我們你可以總結(jié)出核心問題的求解在于我們需要統(tǒng)計(jì)出一組數(shù)字在序列中出現(xiàn)的次數(shù)。

3.1 提取輸出的key

因?yàn)橥庥^數(shù)列中每個(gè)子項(xiàng)都是統(tǒng)計(jì)數(shù)字key出現(xiàn)的次數(shù),所以我們可以利用groupby函數(shù)來獲取子項(xiàng)中需要描述的key值,

樣例如下:

>>>[key for key, group in groupby('AAAABBBCCDAABBB')]
[A, B, C, D, A, B]

3.2 提取每個(gè)key對(duì)應(yīng)的value

正如上述輸出所展示的,我們使用groupby函數(shù)將同一key進(jìn)行分組。因此,我們可以對(duì)每個(gè)key對(duì)應(yīng)的value進(jìn)行類型轉(zhuǎn)換,

如下:

>>>[list(group) for key, group in groupby('AAAABBBCCDAABBB')]
[['A', 'A', 'A', 'A'], ['B', 'B', 'B'], ['C', 'C'], ['D'], ['A', 'A'], ['B', 'B', 'B']]

3.3 統(tǒng)計(jì)每個(gè)group對(duì)應(yīng)的長度

經(jīng)過上述轉(zhuǎn)換,我們按照key值對(duì)數(shù)列中的子項(xiàng)進(jìn)行了分組,進(jìn)而我們可以獲取每個(gè)group的長度,代碼如下:

>>>[len(list(group)) for key, group in groupby('AAAABBBCCDAABBB')]
[4, 3, 2, 1, 2, 3]

3.4 整合輸出

通過上述一步步的分析,我們已經(jīng)很方便地使用groupby來實(shí)現(xiàn)我們需要的輸出了,我們只需要整合每個(gè)group分組后的長度以及其key即可,

代碼如下:

>>>[(len(list(group)),key) for key, group in groupby('AAAABBBCCDAABBB')]
[(4, 'A'), (3, 'B'), (2, 'C'), (1, 'D'), (2, 'A'), (3, 'B')]

3.5 解決方案

正如以上的分析,我們知道元組包含每個(gè)值的計(jì)數(shù)和值本身。我們可以使用上面的邏輯,用Python來實(shí)現(xiàn)外觀數(shù)列的求解!

代碼如下:

我們這里打印該數(shù)列的前15項(xiàng),即讓參數(shù)iterator = 15,此時(shí)的輸出如下:

4. 總結(jié)

本文通過一道非常有趣的題目引入了外觀數(shù)列的定義,然后通過舉例分析找出用Python實(shí)現(xiàn)該功能的快捷方式,最后給出了整個(gè)問題求解的樣例代碼。

到此這篇關(guān)于利用Python實(shí)現(xiàn)外觀數(shù)列求解的文章就介紹到這了,更多相關(guān)Python外觀數(shù)列求解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python實(shí)現(xiàn)圖形用戶界面和游戲開發(fā)的方法和技巧

    Python實(shí)現(xiàn)圖形用戶界面和游戲開發(fā)的方法和技巧

    GUI圖形用戶界面編程,我們可以通過python提供的豐富的組件,快速的實(shí)現(xiàn)使用圖形的界面和用戶交互, GUI編程類似于“搭積?”,將?個(gè)個(gè)組件(Widget)放到窗?中,這篇文章主要給大家介紹了基于Python的GUI圖形用戶界面編程的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 如何使用Python生成4位數(shù)的隨機(jī)數(shù)字

    如何使用Python生成4位數(shù)的隨機(jī)數(shù)字

    本文討論了如何使用randint() 和randrange() 方法來生成一個(gè)四位數(shù)的數(shù)字,此外,我們還討論了另一種擁有隨機(jī)四位數(shù)號(hào)碼的途徑,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • Django中modelform組件實(shí)例用法總結(jié)

    Django中modelform組件實(shí)例用法總結(jié)

    在本篇文章里小編給大家整理的是關(guān)于Django中modelform組件實(shí)例用法內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)下。
    2020-02-02
  • 如何運(yùn)行帶參數(shù)的python腳本

    如何運(yùn)行帶參數(shù)的python腳本

    這篇文章主要介紹了如何運(yùn)行帶參數(shù)的python腳本,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • python超簡單解決約瑟夫環(huán)問題

    python超簡單解決約瑟夫環(huán)問題

    這篇文章主要介紹了python超簡單解決約瑟夫環(huán)問題的方法,詳細(xì)描述的約瑟夫環(huán)問題的描述與Python解決方法,需要的朋友可以參考下
    2015-05-05
  • python FTP批量下載/刪除/上傳實(shí)例

    python FTP批量下載/刪除/上傳實(shí)例

    今天小編就為大家分享一篇python FTP批量下載/刪除/上傳實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • pytorch的batch normalize使用詳解

    pytorch的batch normalize使用詳解

    今天小編就為大家分享一篇pytorch的batch normalize使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • 學(xué)習(xí)Python爬蟲的幾點(diǎn)建議

    學(xué)習(xí)Python爬蟲的幾點(diǎn)建議

    這篇文章主要介紹了學(xué)習(xí)Python爬蟲的幾點(diǎn)建議,對(duì)新手學(xué)習(xí)爬蟲有很大的幫助,感興趣的朋友可以了解下
    2020-08-08
  • Python socket實(shí)現(xiàn)的簡單通信功能示例

    Python socket實(shí)現(xiàn)的簡單通信功能示例

    這篇文章主要介紹了Python socket實(shí)現(xiàn)的簡單通信功能,結(jié)合實(shí)例形式分析了Python socket通信的相關(guān)概念、原理、客戶端與服務(wù)器端實(shí)現(xiàn)技巧以及socketserver模塊多并發(fā)簡單實(shí)現(xiàn)方法,需要的朋友可以參考下
    2018-08-08
  • python中adb有什么功能

    python中adb有什么功能

    在本篇文章里小編給大家分享的是關(guān)于python中adb有功能的知識(shí)點(diǎn)總結(jié),有需要的可以跟著學(xué)習(xí)下。
    2020-06-06

最新評(píng)論