Rumah Kewangan Peribadi Rasa Rekursi - dummies

Rasa Rekursi - dummies

Video: RASA - Пчеловод | ПРЕМЬЕРА КЛИПА 2019 2024

Video: RASA - Пчеловод | ПРЕМЬЕРА КЛИПА 2019 2024
Anonim

Rekursi adalah perkataan yang besar dan menakutkan yang sering anda dengar tentang pengaturcaraan, terutamanya jenis pengaturcaraan yang mereka ajarkan di universiti. Walaupun ia adalah satu konsep yang mudah untuk menerangkan, ia benar-benar pemikat fikiran ketika datang untuk memahami bagaimana rekursi berfungsi. Kebanyakan orang hanya menerimanya dan teruskan. Bukan disini!

Rekursi pada dasarnya adalah proses fungsi yang memanggilnya sendiri. Sebagai contoh:

void funct (int x) {funct (x);}

Dalam kod ini, anda melihat contoh yang mengerikan dari fungsi rekursif, tetapi berfungsi sebagai ilustrasi di sini: () fungsi panggilan sendiri. Itulah rekursi. Sekarang apa yang berlaku dalam contoh ini pada dasarnya adalah gelung yang tidak berkesudahan, dan, terima kasih kepada sesuatu yang teknikal atau yang disebut, stack pointe r , komputer akhirnya terhempas. Tetapi ia hanya satu ilustrasi.

Untuk rekursi untuk berfungsi, fungsi mesti mempunyai keadaan bailout, seperti gelung. Oleh itu, sama ada nilai yang diluluskan kepada fungsi rekursif atau nilai pulangannya mesti diuji. Berikut adalah contoh yang lebih baik dari fungsi rekursif:

rekursa batal (int x) {jika (x == 0) pulangan; lain {puts ("Boop!"); rekursi (- x);}}

Fungsi rekursi () menerima nilai x . Jika x sama dengan sifar, bails fungsi. Jika tidak, fungsi dipanggil semula, tetapi nilai x dikurangkan. Pengendali awalan susunan digunakan supaya nilai x dikurangkan sebelum panggilan dibuat.

Contoh rekursi () berfungsi pada dasarnya meludahkan teks Boop! beberapa kali. Jadi jika rekursi () dipanggil dengan nilai 10, anda dapat melihat teks yang dipaparkan sepuluh kali.

Bahagian gila tentang rekursi adalah bahawa fungsi terus memanggil sendiri, membungkus dirinya lebih ketat dan ketat, seolah-olah ia berada dalam lingkaran. Dalam contoh terdahulu, keadaan x == 1 akhirnya menenangkan kekacauan yang berliku-liku, semakin menarik kembali sehingga fungsi itu selesai.

Kod berikut menunjukkan program penuh menggunakan fungsi rekursi sampel ().

#include recursion void (int x); int main () {recursion (10); return (0);} void recursion (int x) {if (x == 0) return; lain {puts ("Boop!"); rekursi (- x);}}

Demonstrasi biasa rekursi adalah fungsi faktorial. faktorial adalah hasil daripada mendarabkan nilai oleh setiap integer positifnya. Sebagai contoh:

4! = 4 × 3 × 2 × 1

Hasil faktorial ini ialah 24. Komputer juga boleh membuat pengiraan ini, sama ada melaksanakan gelung atau mencipta fungsi rekursif.Berikut adalah fungsi berikut:

int factorial (int x) {jika (x == 1) pulangan (x); lain kembali (x * factorial (x-1));}

Seperti fungsi rekursif lain, fungsi faktorial () mengandungi keadaan keluar: x == 1. Jika tidak, fungsi itu dipanggil semula dengan satu kurang daripada nilai semasa x . Tetapi semua tindakan berlaku dengan nilai pulangan.

Rasa Rekursi - dummies

Pilihan Editor

Melindungi Metrik Media Sosial anda dengan Alat Cadangan - dummies

Melindungi Metrik Media Sosial anda dengan Alat Cadangan - dummies

Jika anda telah memulakan jejak sosial metrik media dan menikmati kurniaan data yang kini dapat dilihat, dihidupkan, dan digunakan, anda mungkin tertanya-tanya apa yang mungkin menyebabkan kemurungan! Mudah: kehilangan data. Katakanlah bahawa anda mempunyai masalah tapak atau entah bagaimana kehilangan akses ke tapak atau data anda. Adakah anda mempunyai sandaran anda ...

Laman web baru? Menarik Tumpuan Media Sosial Lalu Lintas dan Meningkat - dummies

Laman web baru? Menarik Tumpuan Media Sosial Lalu Lintas dan Meningkat - dummies

Mana-mana kempen baru, laman web, akaun Twitter, halaman Facebook, atau item lain yang anda ingin ukur dengan metrik media sosial bermula pada sifar. Nombor ini boleh membuat anda merasa seperti anda bercakap dengan tidak sah, bercakap dengan diri anda atau anda tersembunyi dari pandangan. Perasaan ini boleh membawa kepada pengasingan secara keseluruhan ...

Meracuni Google Spider - dummies

Meracuni Google Spider - dummies

Anda sentiasa dapat mencari orang yang ingin menyimpang dari lurus dan sempit. Ya, mereka adalah orang bodoh yang terlibat dalam taktik pengoptimuman berisiko yang bertujuan untuk menggerakkan PageRank secara artifisial, memanipulasi pesanan halaman hasil carian di Google, dan mendapatkan kelebihan yang tidak adil dalam indeks. Google, dengan reputasi yang luar biasa untuk melindungi, ...

Pilihan Editor

Mengukur Pengunjung Lama Menginap di Laman Web Anda - dummies

Mengukur Pengunjung Lama Menginap di Laman Web Anda - dummies

Di laman web anda memberikan wawasan yang penting. Anda boleh memikirkan sama ada pengunjung sedang melihat cepat, kemudian pergi, atau sama ada mereka bertahan lebih lama dan sebenarnya membaca bahan dalam talian anda dengan tujuan untuk mengambil tindakan. Jika majoriti pelawat laman web anda tidak ...

Pemasaran web: Cara Menilai Layouts dengan Peta Haba - dummies

Pemasaran web: Cara Menilai Layouts dengan Peta Haba - dummies

Laman web perniagaan sangat mirip dengan merancang kedai dengan pemasaran produk dalam fikiran. Malah, laman web anda benar-benar adalah kedai - kedai maya di Internet. Rangkaian kedai runcit telah menghabiskan berjuta-juta dolar dalam penyelidikan pasaran, menonton dan mendokumentasikan bagaimana pembeli memasuki kedai, belok kanan atau kiri, dan ...

Analitik web Untuk Menipu Cheat Sheet - dummies

Analitik web Untuk Menipu Cheat Sheet - dummies

Melakukan analisis laman web tidak perlu meletihkan dan intensif masa. Anda boleh meringkaskan prestasi keseluruhan laman web anda dengan cepat - jika anda tahu apa yang perlu dicari. Alat analisis web percuma dan kos rendah boleh membantu anda mengukur kejayaan laman web anda, dan anda boleh menjana perujuk tapak dengan pelbagai cara yang tidak mungkin ...

Pilihan Editor

Cara Memaksimumkan Ruang pada Laman Web - dummies

Cara Memaksimumkan Ruang pada Laman Web - dummies

Terlalu terhad, anda boleh membuat penggunaan kreatif beberapa teknologi di luar sana untuk memaksimumkan antara muka anda. Untuk setiap teknik berikut yang diterangkan, terdapat banyak laman web yang menawarkan sampel kod, forum, dan sumber untuk membantu anda memulakan. Accordions. Antara muka akordion membolehkan ...

Cara Mendapatkan Corak CSS3 Online - dummies

Cara Mendapatkan Corak CSS3 Online - dummies

Mencipta kesan mudah untuk laman CSS3 menggunakan gradien mudah . Walau bagaimanapun, mewujudkan sesuatu yang benar-benar hebat memerlukan masa dan keupayaan artistik. Kebanyakan pemaju benar-benar tidak mempunyai masa atau kemahiran yang diperlukan untuk mencipta sesuatu yang mempesonakan menggunakan CSS3 sahaja (atau CSS3 digabungkan dengan grafik) - di sinilah pereka bermain. Ramai pereka yang membolehkan anda ...

Bagaimana Mengoptimumkan Aplikasi CSS3 dengan Modernizr - dummies

Bagaimana Mengoptimumkan Aplikasi CSS3 dengan Modernizr - dummies

Terdapat banyak pelayar dan versi pelayar yang berbeza gunakan hari ini. Tidak semua daripada mereka adalah optimum untuk CSS3. Inilah tempat Modernizr dimainkan. Pemajunya menyebutnya "perpustakaan JavaScript yang mengesan ciri HTML5 dan CSS3 dalam pelayar pengguna. "Anda menggunakan Modernizr untuk melaksanakan tugas secara pilihan dan memasukkan ciri aplikasi berdasarkan ...