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!

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

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

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

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

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

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

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

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


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Dreamweaver Mac版
Alat pembangunan web visual
