Rumah pembangunan bahagian belakang C++ Menggunakan ruang tambahan untuk fungsi rekursif dalam program C?

Menggunakan ruang tambahan untuk fungsi rekursif dalam program C?

Sep 05, 2023 am 10:01 AM
c program fungsi rekursif ruang bantu

Menggunakan ruang tambahan untuk fungsi rekursif dalam program C?

Di sini kita akan melihat bagaimana panggilan fungsi rekursif memerlukan ruang tambahan. Bagaimanakah ia berbeza daripada panggilan fungsi biasa?

Andaikan kita mempunyai fungsi seperti yang ditunjukkan di bawah -

long fact(int n){
   if(n == 0 || n == 1)
      return 1;
   return n * fact(n-1);
}
Salin selepas log masuk

Fungsi ini adalah fungsi rekursif. Apabila kita memanggilnya seperti fakta(5), ia akan menyimpan alamat di dalam tindanan seperti yang ditunjukkan di bawah -

fact(5) --->
fact(4) --->
fact(3) --->
fact(2) --->
fact(1)
Salin selepas log masuk

Apabila fungsi rekursif memanggil dirinya berulang kali, alamat itu ditambahkan pada tindanan. Oleh itu, jika fungsi dipanggil secara rekursif n kali, ia akan menduduki ruang tambahan O(n). Tetapi ini tidak bermakna jika fungsi normal dipanggil n kali, kerumitan ruang akan menjadi O(n). Untuk fungsi biasa, alamat ditolak ke tindanan apabila dipanggil. Setelah selesai, alamat akan muncul dari timbunan dan dimasukkan ke dalam fungsi pemanggil. Kemudian telefon semula. Jadi kerumitannya ialah O(1).

Atas ialah kandungan terperinci Menggunakan ruang tambahan untuk fungsi rekursif dalam program C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

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.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Terjemahkan yang berikut ke dalam bahasa Cina: Program C untuk menukar angka Rom kepada nombor perpuluhan Terjemahkan yang berikut ke dalam bahasa Cina: Program C untuk menukar angka Rom kepada nombor perpuluhan Sep 05, 2023 pm 09:53 PM

Diberikan di bawah adalah algoritma bahasa C untuk menukar angka Rom kepada nombor perpuluhan: Algoritma Langkah 1 - Mulakan Langkah 2 - Baca angka Rom pada masa jalan Langkah 3 - Panjang: = strlen(roman) Langkah 4 - Untuk i=0 kepada Length-1 Langkah 4.1-suis(roman[i]) Langkah 4.1.1-case'm': &nbs

Apakah teknik pengoptimuman untuk fungsi rekursif C++? Apakah teknik pengoptimuman untuk fungsi rekursif C++? Apr 17, 2024 pm 12:24 PM

Untuk mengoptimumkan prestasi fungsi rekursif, anda boleh menggunakan teknik berikut: Gunakan rekursif ekor: Buat panggilan rekursif pada penghujung fungsi untuk mengelakkan overhed rekursif. Memoisasi: Simpan hasil pengiraan untuk mengelakkan pengiraan berulang. Kaedah bahagi dan takluk: menguraikan masalah dan menyelesaikan sub-masalah secara rekursif untuk meningkatkan kecekapan.

Program C++ untuk mencari nilai fungsi sinus hiperbolik songsang mengambil nilai yang diberikan sebagai hujah Program C++ untuk mencari nilai fungsi sinus hiperbolik songsang mengambil nilai yang diberikan sebagai hujah Sep 17, 2023 am 10:49 AM

Fungsi hiperbola ditakrifkan menggunakan hiperbola dan bukannya bulatan dan bersamaan dengan fungsi trigonometri biasa. Ia mengembalikan parameter nisbah dalam fungsi sinus hiperbolik dari sudut yang dibekalkan dalam radian. Tetapi lakukan sebaliknya, atau dengan kata lain. Jika kita ingin mengira sudut daripada sinus hiperbolik, kita memerlukan operasi trigonometri hiperbolik songsang seperti operasi sinus songsang hiperbolik. Kursus ini akan menunjukkan cara menggunakan fungsi sinus songsang hiperbolik (asinh) dalam C++ untuk mengira sudut menggunakan nilai sinus hiperbolik dalam radian. Operasi arcsine hiperbolik mengikut formula berikut -$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})}, Di mana\:In\:is\:logaritma asli\:(log_e\:k)

Program C untuk mencari panjang senarai terpaut Program C untuk mencari panjang senarai terpaut Sep 07, 2023 pm 07:33 PM

Senarai terpaut menggunakan peruntukan memori dinamik, iaitu ia berkembang dan mengecut dengan sewajarnya. Ia ditakrifkan sebagai koleksi nod. Di sini, nod mempunyai dua bahagian, data dan pautan. Data, pautan dan senarai terpaut diwakili seperti berikut - Jenis senarai terpaut Terdapat empat jenis senarai terpaut, seperti berikut: - Senarai pautan tunggal / Senarai pautan tunggal Senarai berganda / Berganda Pekeliling Senarai pautan tunggal Pekeliling Senarai pautan berganda Kami menggunakan kaedah rekursif untuk mencari panjang senarai terpaut Logiknya ialah -intlength(nod *temp){ if(temp==NULL) returnl{&n

Program C++ untuk mencetak kamus Program C++ untuk mencetak kamus Sep 11, 2023 am 10:33 AM

Peta ialah sejenis bekas khas dalam C++ di mana setiap elemen adalah sepasang dua nilai, iaitu nilai kunci dan nilai dipetakan. Nilai kunci digunakan untuk mengindeks setiap item, dan nilai yang dipetakan ialah nilai yang dikaitkan dengan kunci. Tidak kira sama ada nilai yang dipetakan adalah unik, kuncinya sentiasa unik. Untuk mencetak elemen peta dalam C++ kita perlu menggunakan iterator. Elemen dalam set item ditunjukkan oleh objek iterator. Iterator digunakan terutamanya dengan tatasusunan dan jenis bekas lain (seperti vektor), dan mereka mempunyai set operasi khusus yang boleh digunakan untuk mengenal pasti elemen tertentu dalam julat tertentu. Iterator boleh dinaikkan atau dikurangkan untuk merujuk elemen berbeza yang terdapat dalam julat atau bekas. Peulang menunjuk ke lokasi memori elemen tertentu dalam julat. Mencetak peta dalam C++ menggunakan iterator Mula-mula, mari lihat cara untuk mentakrifkan

Penggunaan fungsi rekursif C++ dalam algoritma carian? Penggunaan fungsi rekursif C++ dalam algoritma carian? Apr 17, 2024 pm 04:30 PM

Fungsi rekursif digunakan dalam algoritma carian untuk meneroka struktur data seperti pokok. Carian pertama mendalam menggunakan timbunan untuk meneroka nod, manakala carian pertama keluasan menggunakan baris gilir untuk melintasi lapisan demi lapisan. Dalam aplikasi praktikal, seperti mencari fail, fungsi rekursif boleh digunakan untuk mencari fail tertentu dalam direktori tertentu.

Program C menggunakan fungsi rename() untuk menukar nama fail Program C menggunakan fungsi rename() untuk menukar nama fail Sep 21, 2023 pm 10:01 PM

Fungsi nama semula menukar fail atau direktori daripada nama lamanya kepada nama baharunya. Operasi ini serupa dengan operasi bergerak. Jadi kita juga boleh menggunakan fungsi nama semula ini untuk memindahkan fail. Fungsi ini wujud dalam fail pengepala perpustakaan stdio.h. Sintaks fungsi nama semula adalah seperti berikut: intrename(constchar*oldname,constchar*newname); Fungsi rename() fungsi menerima dua parameter. Satu nama lama dan satu lagi nama baru. Kedua-dua parameter adalah penunjuk kepada aksara malar yang mentakrifkan nama lama dan baharu fail. Mengembalikan sifar jika fail berjaya dinamakan semula, jika tidak, mengembalikan integer bukan sifar. Semasa operasi menamakan semula

Program C++ untuk mendapatkan bahagian khayalan nombor kompleks yang diberikan Program C++ untuk mendapatkan bahagian khayalan nombor kompleks yang diberikan Sep 06, 2023 pm 06:05 PM

Sains moden sangat bergantung pada konsep nombor jamak, yang pertama kali ditubuhkan pada awal abad ke-17 oleh Girolamo Cardano, yang memperkenalkannya pada abad ke-16. Formula untuk nombor kompleks ialah a+ib, dengan a memegang kod html dan b ialah nombor nyata. Nombor kompleks dikatakan mempunyai dua bahagian: bahagian nyata <a> dan bahagian khayalan (<ib>). Nilai i atau iota ialah √-1. Kelas jamak dalam C++ ialah kelas yang digunakan untuk mewakili nombor kompleks. Kelas kompleks dalam C++ boleh mewakili dan mengawal beberapa operasi nombor kompleks. Mari kita lihat bagaimana untuk mewakili dan mengawal paparan nombor majmuk. imag() fungsi ahli Seperti yang dinyatakan di atas, nombor kompleks terdiri daripada bahagian nyata dan bahagian khayalan. Untuk memaparkan bahagian sebenar kami menggunakan real()

See all articles