搜尋

火柴棍壓縮

Nov 25, 2024 pm 03:56 PM

Matchstick compression

每週挑戰 296

穆罕默德·S·安瓦爾 (Mohammad S. Anwar) 每週都會發出“每週挑戰”,讓我們所有人都有機會為每週兩次的任務提出解決方案。我的解決方案先用Python編寫,然後轉換為Perl。這對我們所有人來說都是練習編碼的好方法。

挑戰,我的解決方案

任務 1:字串壓縮

任務

您將獲得一串字母字符,$chars。

編寫一個腳本,使用遊程編碼來壓縮字串,如範例所示。

壓縮單元可以是單一字符,也可以是計數後面跟著一個字符。

獎勵:寫一個解壓縮函數。

我的解決方案

由於正規表示式的強大功能,這是一項非常簡單的任務。 Python 和 Perl 都允許替換值是一個函數。因此,我有一個名為 sc 的函數,它將多個字母轉換為數字和字母。例如如果輸入是aaa,它將回傳3a。

def sc(match):
    m = match.group(0)
    return str(len(m)) + m[0]

然後就是根據需要呼叫這個函數了。

def string_compress(s: str) -> str:
    return re.sub(r'(([a-z])+)', sc, s)

解壓縮函數(僅限Python)以類似的方式運作。它採用數字後面跟著字母的模式,並將其更改為重複指定次數的字母。

def usc(match):
    m = match.group(0)
    return m[-1] * int (m[:-1])

def string_decompress(s: str) -> str:
    return re.sub(r'(\d+[a-z])', usc, s)

為了從命令列執行,我使用 argparse 模組來查看是否指定了 --decompress 選項。

def main():
    parser = argparse.ArgumentParser()
    parser.add_argument("--decompress", help="decompress the input", action='store_true')
    parser.add_argument("str", help="the string to compress/decompress")
    args = parser.parse_args()

    if args.decompress:
        result = string_decompress(args.str)
    else:
        result = string_compress(args.str)
    print(result)

範例

$ ./ch-1.py abbc
a2bc

$ ./ch-1.py aaabccc
3ab3c

$ ./ch-1.py abcc
ab2c

$ ./ch-1.py --decompress a2bc
abbc

$ ./ch-1.py --decompress 3ab3c
aaabccc

$ ./ch-1.py --decompress ab2c
abcc

任務2:火柴方

任務

給你一個整數數組,@ints。

編寫一個腳本來查找是否可以使用給定數組 @ints 中的棍子製作一個正方形,其中 $ints[ì] 是第 i 根棍子的長度。

我的解決方案

這會有點長,所以請繫好安全帶。我檢查的第一件事是木棍的總和是否能被四整除。如果不是,沒有可能的解決方案,我可以回傳 false

我還可以檢查沒有一根棍子比一邊長。如果發生這種情況,我也會回傳 false。

透過這兩項檢查,所有範例都會給出正確的結果。然而,它會錯誤地報告 4 3 3 3 3 為真,但實際上並非如此。

嘗試二

查看範例和我自己的想法,我認為解決方案是匹配一對值來匹配每一側。因此,對於例 3 4 1 4 3 1,我們有兩對 3 和 1 棍子,組成四根棍子。這將解決 4 3 3 3 3 問題,因為 3 沒有匹配的。

但是如果棍子是 4 4 3 1 2 1 1,這將不起作用,因為一側使用三根棍子(一根 2 和兩根 1)

試三

所以我的下一次嘗試有點複雜,我認為這是一個很好的解決方案......直到它不是。對於這次嘗試,我從最長的棍子開始。如果不是邊的長度,我就拿完成邊所需的下一根最長的棍子,然後重複,直到沒有可能的解決方案。使用此方法,以下解決方案是正確的。

  • 4 4 3 1 2 1 1
  • 9 5 4 3 3 3 3 3 3
  • 9 6 3 5 4 3 3 3
  • 9 6 3 5 4 3 3 2 1

我以為這就是解決方案,直到我意識到 9 5 3 1 5 2 2 3 3 3 不起作用。第一條邊是 9,下一條邊是 5 3 1,第三邊會失敗,只有 5 3 而沒有 1。

嘗試四

此時,我開始懷疑是否有可能想出一個不涉及暴力的解決方案。所以我睡在上面,在平板電腦上寫下了很多東西(我正在度假,所以我不能使用我的白板),然後又睡在上面。我的結論是使用遞歸函數是唯一的解決方案。

也許我只是想太多了,或者也許有一個我剛剛想到的真正簡單的解決方案(就像上週的情況)。

最終程式碼

還在讀書嗎?幹得好:)

對於這個任務,我有一個名為 make_side 的遞歸函數。它需要一個剩餘棍棒的清單(Perl 中的 arrayref)以及所需的長度。然後它會遍歷剩餘的棍子(首先是最高的)。然後發生以下三件事之一:

  • 如果棍子比要求的長度長,我會跳過它。
  • 如果是需要的長度,我就回。
  • 如果它很短,我會使用它並再次調用該函數以使用另一根棍子。此呼叫會刪除已使用的棍子,並根據已使用的棍子的長度減少所需的長度。

該函數將傳回所使用的棍子列表,如果未找到有效的棍子組合,則傳回 None(Perl 中的 undef)。

def sc(match):
    m = match.group(0)
    return str(len(m)) + m[0]

拼圖的最後一塊,我執行第一部分中提到的檢查(總和可以被四整除,長度不能超過邊長),然後呼叫上面的函數。如果返回 None,我返回 false。如果所有的棍子都被使用,我返回true。

def string_compress(s: str) -> str:
    return re.sub(r'(([a-z])+)', sc, s)

範例

def usc(match):
    m = match.group(0)
    return m[-1] * int (m[:-1])

def string_decompress(s: str) -> str:
    return re.sub(r'(\d+[a-z])', usc, s)

以上是火柴棍壓縮的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
了解差異:用於循環和python中的循環了解差異:用於循環和python中的循環May 16, 2025 am 12:17 AM

theDifferenceBetweewneaforoopandawhileLoopInpythonisthataThataThataThataThataThataThataNumberoFiterationSiskNownInAdvance,而leleawhileLoopisusedWhenaconDitionNeedneedneedneedNeedStobeCheckedStobeCheckedStobeCheckedStobeCheckedStobeceDrepeTysepectients.peatsiveSectlyStheStobeCeptellyWithnumberofiterations.1)forloopsareAceareIdealForitoringercortersence

Python循環控制:對於vs -a -a比較Python循環控制:對於vs -a -a比較May 16, 2025 am 12:16 AM

在Python中,for循環適用於已知迭代次數的情況,而while循環適合未知迭代次數且需要更多控制的情況。 1)for循環適用於遍歷序列,如列表、字符串等,代碼簡潔且Pythonic。 2)while循環在需要根據條件控制循環或等待用戶輸入時更合適,但需注意避免無限循環。 3)性能上,for循環略快,但差異通常不大。選擇合適的循環類型可以提高代碼的效率和可讀性。

如何在Python中結合兩個列表:5種簡單的方法如何在Python中結合兩個列表:5種簡單的方法May 16, 2025 am 12:16 AM

在Python中,可以通過五種方法合併列表:1)使用 運算符,簡單直觀,適用於小列表;2)使用extend()方法,直接修改原列表,適用於需要頻繁更新的列表;3)使用列表解析式,簡潔且可對元素進行操作;4)使用itertools.chain()函數,內存高效,適合大數據集;5)使用*運算符和zip()函數,適用於需要配對元素的場景。每種方法都有其特定用途和優缺點,選擇時應考慮項目需求和性能。

循環時循環:python語法,用例和示例循環時循環:python語法,用例和示例May 16, 2025 am 12:14 AM

foroopsare whenthenemberofiterationsisknown,而whileLoopsareUseduntilacTitionismet.1)ForloopSareIdealForeSequencesLikeLists,UsingSyntaxLike'forfruitinFruitinFruitinFruitIts:print(fruit)'。 2)'

python串聯列表列表python串聯列表列表May 16, 2025 am 12:08 AM

toConcateNateAlistofListsInpython,useextend,listComprehensions,itertools.Chain,orrecursiveFunctions.1)ExtendMethodStraightForwardButverBose.2)listComprechencomprechensionsareconconconciseandemandeconeandefforlargerdatasets.3)

Python中的合併列表:選擇正確的方法Python中的合併列表:選擇正確的方法May 14, 2025 am 12:11 AM

Tomergelistsinpython,YouCanusethe操作員,estextMethod,ListComprehension,Oritertools

如何在Python 3中加入兩個列表?如何在Python 3中加入兩個列表?May 14, 2025 am 12:09 AM

在Python3中,可以通過多種方法連接兩個列表:1)使用 運算符,適用於小列表,但對大列表效率低;2)使用extend方法,適用於大列表,內存效率高,但會修改原列表;3)使用*運算符,適用於合併多個列表,不修改原列表;4)使用itertools.chain,適用於大數據集,內存效率高。

Python串聯列表字符串Python串聯列表字符串May 14, 2025 am 12:08 AM

使用join()方法是Python中從列表連接字符串最有效的方法。 1)使用join()方法高效且易讀。 2)循環使用 運算符對大列表效率低。 3)列表推導式與join()結合適用於需要轉換的場景。 4)reduce()方法適用於其他類型歸約,但對字符串連接效率低。完整句子結束。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

北端:融合系統,解釋
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
4 週前By尊渡假赌尊渡假赌尊渡假赌
<🎜>掩蓋:探險33-如何獲得完美的色度催化劑
2 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。