Hem Personliga finanser En smak av rekursion - dummies

En smak av rekursion - dummies

Video: Week 0 2025

Video: Week 0 2025
Anonim

Recursion är ett stort, läskigt ord som du ofta hör om programmering, särskilt den frustrerande typen programmering som de lär på universitetet. Även om det är ett enkelt koncept att beskriva, är det verkligen en tankefläkt när det gäller att förstå hur rekursionen fungerar. De flesta människor accepterar bara det och fortsätter. Inte här!

Rekursion är i grunden processen för en funktion som kallar sig. Till exempel:

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

I denna bit av kod ser du ett fruktansvärt exempel på en rekursiv funktion, men det tjänar illustrativa syften här: Funktionen () funktionen kallar sig själv. Det är rekursion. Nu vad som händer i det här exemplet är i grunden en oändlig loop och, tack vare en teknisk något-eller-annan, kallad stack pointe r , kraschar datorn slutligen. Men det är bara en illustration.

För rekursion till arbete, måste funktionen ha ett bailout-tillstånd, precis som en slinga. Därför måste antingen värdet som skickas till den rekursiva funktionen eller dess returvärde testas. Här är ett bättre exempel på en rekursiv funktion:

void recursion (int x) {if (x == 0) returnerar; annars {sätter ("Boop!"); rekursion (- x);}}

Recursion () -funktionen accepterar värdet x . Om x är lika med noll, böjer funktionen. Annars kallas funktionen igen, men värdet x är reducerat. Operatören för minskningsprefix används så att värdet x minskas före samtalet görs.

Funktionen för rekursutnyttjande () spetsar i princip texten Boop! ett givet antal gånger. Så om recursion () kallas med värdet 10, ser du att texten visas tio gånger.

Den vansinniga delen om rekursion är att funktionen fortsätter att kalla sig själv, förpackning sig strängare och hårdare, som om den är i en spiral. I det föregående exemplet avbryter tillståndet x == 1 slutligen den vridna röra, alltmer dra tillbaka tills funktionen är klar.

Följande kod visar ett fullständigt program med hjälp av funktionen "recursion ()".

#include void recursion (int x); int main () {recursion (10); returnera (0);} void recursion (int x) {if (x == 0) returnera; annars {sätter ("Boop!"); rekursion (- x);}}

En gemensam demonstration av rekursion är en faktoriell funktion. factorial är resultatet av att ett värde multipliceras med var och en av dess positiva heltal. Till exempel:

4! = 4 × 3 × 2 × 1

Resultatet av denna factorial är 24. Datorn kan också göra denna beräkning genom att antingen implementera en loop eller skapa en rekursiv funktion.Här är en sådan funktion:

int factorial (int x) {if (x == 1) returnera (x); annars returnerar (x * factorial (x-1));}

Som med de andra rekursiva funktionerna innehåller funktionen factorial () ett utgångsförhållande: x == 1. Annars kallas funktionen igen med en mindre än det nuvarande värdet på x . Men all åtgärd sker med returvärdena.

En smak av rekursion - dummies

Redaktörens val

Office 365 Grupper - Dummies

Office 365 Grupper - Dummies

Du kan använda Office 365 Grupper, eller helt enkelt grupper, för att snabbt bandet tillsammans med medarbetare till samarbeta utan administrationsansvar som följer med en SharePoint-webbplats. Grupper är inte en del av SharePoint Online. Det är faktiskt en funktion i Exchange Online, men den använder SharePoint Online-funktioner, till exempel OneDrive for Business för att lagra gruppfiler ...

Office 365 Mobil Dokument i molnet - Dummies

Office 365 Mobil Dokument i molnet - Dummies

Varje Office 365-abonnent med en kvalificerad plan kan installera Office mobilappar på upp till fem tabletter och fem smartphones. Kvalificeringsplanerna är: Office for Business Premium, Office 365 Business, Office 365 Pro Plus, Office 365 E3 och Office 365 E5. Kärnan Office-appar finns i Windows, iOS och Android ...

Office Graph och Delve - dummies

Office Graph och Delve - dummies

Office Graph i Office 365 ger en möjlighet för människor att dra nytta av relationer och aktiviteter och göra dem till meningsfulla insikter. De signaler du skickar från e-postkonversationer och möten i Outlook, snabbmeddelanden i Skype for Business, sociala interaktioner på Yammer och dokument i SharePoint Online och OneDrive samlas alla och ...

Redaktörens val

Elektronik Komponenter: Sätt in induktorer till arbete - dummies

Elektronik Komponenter: Sätt in induktorer till arbete - dummies

Om du har undrat vad induktorer används egentligen i elektroniska kretsar i verkligheten, här är några av de vanligaste användningarna för induktorer: Utjämning av spänning i en strömförsörjning: Det sista steget i en typisk strömförsörjningskrets som omvandlar 120 VAC hushållsström till en användbar direkt Nuvarande är ofta en ...

Elektronik Komponenter: Introduktion av mikrokontroller - dummies

Elektronik Komponenter: Introduktion av mikrokontroller - dummies

En mikrokontroller är en komplett dator på en enda elektronisk chip. De kan köpas för $ 50 eller mindre. Liksom alla datorsystem består mikrodatorer av flera grundläggande delsystem: Central Processor (CPU): En CPU utför de instruktioner som tillhandahålls av ett program. CPU kan göra alla nödvändiga åtgärder för ...

Elektronik Komponenter: Motstånd Power Ratings - dummies

Elektronik Komponenter: Motstånd Power Ratings - dummies

Motstånd är som bromsar för ström som strömmar genom en elektronisk krets. Liksom bromsarna i din bil arbetar motstånd genom att använda den elektriska ekvivalenten av friktion till strömningsströmmen. Denna friktion hämmar strömmen av ström genom att absorbera en del av strömens energi och sprida den i form av värme. När du använder en ...

Redaktörens val

Hur man konfigurerar SSH för din webbplats - dummies

Hur man konfigurerar SSH för din webbplats - dummies

Secure shell (SSH) är ett nätverksprotokoll för att tillåta säker datakommunikation. I själva verket är det som en webbhotell bakdörr i ditt system - en som borde förbli låst om du inte behöver använda den. Naturligtvis är exakt hur du konfigurerar SSH olika på alla typer av webbhotell, men som ...

Hur man skapar en ny webbhotell - dummies

Hur man skapar en ny webbhotell - dummies

Du måste skapa din databas inom din webbhotellskontrollpanel och skapa en speciell databasanvändare som har behörighet att komma åt den. När du installerar en webbapplikation eller ett skript som kräver en databas från kontrollpanelen, kommer installationsprogrammet sannolikt att kunna skapa en egen databas och användare. ...

Hur man skapar nya konton på webbhotell med FTP-dummies

Hur man skapar nya konton på webbhotell med FTP-dummies

Du kanske vill att skapa ytterligare konton på en webbhanterad ftp av olika orsaker. Detta möjliggör viss mångsidighet och kontroll för att förbättra din företagsfunktionalitet. Några skäl till att lägga till ett konto är följande: Du vill ge någon annan FTP-åtkomst till din webbplats. Du vill ge någon FTP-åtkomst ...