cari
Mampatan batang mancisNov 25, 2024 pm 03:56 PM

Matchstick compression

Cabaran Mingguan 296

Setiap minggu Mohammad S. Anwar menghantar Cabaran Mingguan, peluang untuk kita semua mencari penyelesaian kepada dua tugas mingguan. Penyelesaian saya ditulis dalam Python terlebih dahulu, dan kemudian ditukar kepada Perl. Ini cara yang bagus untuk kita semua mempraktikkan beberapa pengekodan.

Cabaran, Penyelesaian saya

Tugasan 1: Mampatan Rentetan

Tugasan

Anda diberi rentetan aksara abjad, $chars.

Tulis skrip untuk memampatkan rentetan dengan pengekodan panjang larian, seperti yang ditunjukkan dalam contoh.

Unit termampat boleh sama ada satu aksara atau kiraan diikuti dengan aksara.

BONUS: Tulis fungsi penyahmampatan.

penyelesaian saya

Terima kasih kepada kuasa ungkapan biasa, ini adalah tugas yang agak lurus ke hadapan. Kedua-dua Python dan Perl membenarkan nilai gantian menjadi fungsi. Oleh itu saya mempunyai fungsi yang dipanggil sc yang akan menukar beberapa huruf menjadi nombor dan huruf. Contohnya jika input ialah aaa, ia akan mengembalikan 3a.

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

Maka ia adalah masalah untuk memanggil fungsi ini mengikut keperluan.

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

Fungsi nyahmampat (Python sahaja) berfungsi dengan cara yang sama. Ia memerlukan corak nombor diikuti dengan huruf dan menukarnya kepada huruf yang mengulangi bilangan kejadian yang ditentukan.

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)

Untuk pelaksanaan daripada baris arahan, saya menggunakan modul argparse untuk melihat sama ada pilihan --decompress ditentukan.

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)

Contoh

$ ./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

Tugasan 2: Petak Mancis

Tugasan

Anda diberi tatasusunan integer, @ints.

Tulis skrip untuk mengetahui sama ada boleh membuat satu segi empat sama menggunakan kayu seperti dalam tatasusunan @ints yang diberikan dengan $ints[ì] ialah panjang kayu ke-i.

penyelesaian saya

Ini akan menjadi sedikit panjang, jadi ikat diri anda. Perkara pertama yang saya periksa ialah jumlah batang boleh dibahagi dengan empat. Jika tidak, tiada penyelesaian yang mungkin dan saya boleh mengembalikan palsu

Saya juga boleh menyemak bahawa tiada satu batang lebih panjang daripada satu sisi. Jika ini berlaku, saya juga membalas palsu.

Dengan dua semakan ini, semua contoh akan memberikan hasil yang betul. Walau bagaimanapun, ia akan tersilap melaporkan bahawa 4 3 3 3 3 adalah benar sedangkan ia sebenarnya tidak.

Percubaan dua

Melihat contoh dan pemikiran saya sendiri, saya fikir penyelesaiannya ialah memadankan sepasang nilai untuk dipadankan dengan setiap sisi. Jadi untuk contoh 3 4 1 4 3 1 kita mempunyai dua pasang batang 3 dan 1 yang menjadikan empat. Ini akan menyelesaikan isu 4 3 3 3 3, kerana tiga tidak mempunyai yang sepadan.

Tetapi ini tidak akan berfungsi jika kayu itu 4 4 3 1 2 1 1, kerana sebelah menggunakan tiga kayu (satu 2 dan dua 1)

Percubaan tiga

Jadi percubaan saya yang seterusnya adalah lebih rumit sedikit, dan saya fikir adalah penyelesaian yang baik ... sehingga tidak. Untuk percubaan ini, saya mulakan dengan kayu terpanjang. Jika ia bukan panjang sisi, saya kemudian mengambil kayu terpanjang seterusnya yang diperlukan untuk melengkapkan sisi, dan mengulangi sehingga tiada penyelesaian yang mungkin. Menggunakan kaedah ini penyelesaian berikut adalah benar.

  • 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

Saya fikir ini adalah penyelesaiannya, sehingga saya menyedari bahawa 9 5 3 1 5 2 2 3 3 3 tidak akan berfungsi. Bahagian pertama ialah 9, bahagian seterusnya ialah 5 3 1, dan bahagian ketiga akan gagal dengan 5 3 dan no 1.

Percubaan empat

Pada ketika ini, saya mula tertanya-tanya sama ada ia mungkin untuk menghasilkan penyelesaian yang tidak melibatkan kekerasan. Jadi saya tidur di atasnya, mencoretkan banyak perkara dalam tablet saya (saya sedang bercuti jadi tidak boleh menggunakan papan putih saya), dan tidur di atasnya semula. Kesimpulan saya ialah menggunakan fungsi rekursif adalah satu-satunya penyelesaian.

Mungkin saya terlalu memikirkan semua ini, atau mungkin ada penyelesaian mudah yang baru saya fikirkan (seperti yang berlaku minggu lepas).

Kod terakhir

Masih membaca? Syabas :)

Untuk tugasan ini, saya mempunyai fungsi rekursif yang dipanggil make_side. Ia memerlukan senarai (arrayref dalam Perl) kayu yang tinggal, dan panjang yang diperlukan. Ia kemudian pergi melalui kayu yang tinggal (tertinggi dahulu). Kemudian satu daripada tiga perkara berlaku:

  • Jika kayu itu lebih panjang daripada panjang yang diperlukan, saya langkau.
  • Jika panjang yang diperlukan, saya pulangkan.
  • Jika ia pendek, saya menggunakannya dan memanggil fungsi itu semula untuk menggunakan batang lain. Panggilan itu mengeluarkan kayu terpakai dan mengurangkan panjang yang diperlukan dengan panjang kayu terpakai.

Fungsi ini akan mengembalikan senarai kayu yang digunakan, atau Tiada (undef dalam Perl) jika tiada gabungan kayu yang sah ditemui.

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

Sekeping akhir teka-teki, saya melakukan semakan yang dinyatakan dalam bahagian pertama (jumlah boleh dibahagikan dengan empat, tidak melekat lebih daripada satu sisi), dan kemudian memanggil fungsi di atas. Jika itu mengembalikan Tiada, saya kembali palsu. Jika semua kayu digunakan, saya kembali benar.

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

Contoh

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)

Atas ialah kandungan terperinci Mampatan batang mancis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Cara Menggunakan Python untuk Mencari Pengagihan Zipf Fail TeksCara Menggunakan Python untuk Mencari Pengagihan Zipf Fail TeksMar 05, 2025 am 09:58 AM

Tutorial ini menunjukkan cara menggunakan Python untuk memproses konsep statistik undang -undang ZIPF dan menunjukkan kecekapan membaca dan menyusun fail teks besar Python semasa memproses undang -undang. Anda mungkin tertanya -tanya apa maksud pengedaran ZIPF istilah. Untuk memahami istilah ini, kita perlu menentukan undang -undang Zipf. Jangan risau, saya akan cuba memudahkan arahan. Undang -undang Zipf Undang -undang Zipf hanya bermaksud: Dalam korpus bahasa semulajadi yang besar, kata -kata yang paling kerap berlaku muncul kira -kira dua kali lebih kerap sebagai kata -kata kerap kedua, tiga kali sebagai kata -kata kerap ketiga, empat kali sebagai kata -kata kerap keempat, dan sebagainya. Mari kita lihat contoh. Jika anda melihat corpus coklat dalam bahasa Inggeris Amerika, anda akan melihat bahawa perkataan yang paling kerap adalah "th

Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?Mar 10, 2025 pm 06:54 PM

Artikel ini menerangkan cara menggunakan sup yang indah, perpustakaan python, untuk menghuraikan html. Ia memperincikan kaedah biasa seperti mencari (), find_all (), pilih (), dan get_text () untuk pengekstrakan data, pengendalian struktur dan kesilapan HTML yang pelbagai, dan alternatif (sel

Cara memuat turun fail di pythonCara memuat turun fail di pythonMar 01, 2025 am 10:03 AM

Python menyediakan pelbagai cara untuk memuat turun fail dari Internet, yang boleh dimuat turun melalui HTTP menggunakan pakej Urllib atau Perpustakaan Permintaan. Tutorial ini akan menerangkan cara menggunakan perpustakaan ini untuk memuat turun fail dari URL dari Python. Permintaan Perpustakaan Permintaan adalah salah satu perpustakaan yang paling popular di Python. Ia membolehkan menghantar permintaan HTTP/1.1 tanpa menambahkan rentetan pertanyaan secara manual ke URL atau pengekodan data pos. Perpustakaan Permintaan boleh melaksanakan banyak fungsi, termasuk: Tambah data borang Tambah fail berbilang bahagian Akses data tindak balas python Buat permintaan kepala

Penapisan gambar di pythonPenapisan gambar di pythonMar 03, 2025 am 09:44 AM

Berurusan dengan imej yang bising adalah masalah biasa, terutamanya dengan telefon bimbit atau foto kamera resolusi rendah. Tutorial ini meneroka teknik penapisan imej di Python menggunakan OpenCV untuk menangani isu ini. Penapisan Imej: Alat yang berkuasa Penapis Imej

Cara Bekerja Dengan Dokumen PDF Menggunakan PythonCara Bekerja Dengan Dokumen PDF Menggunakan PythonMar 02, 2025 am 09:54 AM

Fail PDF adalah popular untuk keserasian silang platform mereka, dengan kandungan dan susun atur yang konsisten merentasi sistem operasi, peranti membaca dan perisian. Walau bagaimanapun, tidak seperti Python memproses fail teks biasa, fail PDF adalah fail binari dengan struktur yang lebih kompleks dan mengandungi unsur -unsur seperti fon, warna, dan imej. Mujurlah, tidak sukar untuk memproses fail PDF dengan modul luaran Python. Artikel ini akan menggunakan modul PYPDF2 untuk menunjukkan cara membuka fail PDF, mencetak halaman, dan mengekstrak teks. Untuk penciptaan dan penyuntingan fail PDF, sila rujuk tutorial lain dari saya. Penyediaan Inti terletak pada menggunakan modul luaran PYPDF2. Pertama, pasangkannya menggunakan PIP: Pip adalah p

Cara Cache Menggunakan Redis dalam Aplikasi DjangoCara Cache Menggunakan Redis dalam Aplikasi DjangoMar 02, 2025 am 10:10 AM

Tutorial ini menunjukkan cara memanfaatkan caching redis untuk meningkatkan prestasi aplikasi python, khususnya dalam rangka kerja Django. Kami akan merangkumi pemasangan Redis, konfigurasi Django, dan perbandingan prestasi untuk menyerlahkan bene

Memperkenalkan Toolkit Bahasa Alam (NLTK)Memperkenalkan Toolkit Bahasa Alam (NLTK)Mar 01, 2025 am 10:05 AM

Pemprosesan bahasa semulajadi (NLP) adalah pemprosesan bahasa manusia secara automatik atau separa automatik. NLP berkait rapat dengan linguistik dan mempunyai hubungan dengan penyelidikan dalam sains kognitif, psikologi, fisiologi, dan matematik. Dalam sains komputer

Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?Mar 10, 2025 pm 06:52 PM

Artikel ini membandingkan tensorflow dan pytorch untuk pembelajaran mendalam. Ia memperincikan langkah -langkah yang terlibat: penyediaan data, bangunan model, latihan, penilaian, dan penempatan. Perbezaan utama antara rangka kerja, terutamanya mengenai grap pengiraan

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual