Hem Personliga finanser En smak av rekursion - dummies

En smak av rekursion - dummies

Video: Week 0 2024

Video: Week 0 2024
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

Jewish Funeral Traditions - dummies

Jewish Funeral Traditions - dummies

Judiska begravningar sker vanligen i en synagoge, begravningshem eller på en kyrkogård. Med tradition är judiska begravningar enkla (symboliserar tron ​​att människor är alla lika i döden), men de varierar mycket och har ingen uppsättning liturgi. Att skicka blommor till ett begravnings- eller sorgshem är starkt avskräckt i judendomen. Inte bara kommer ...

Identifiera komplicerade grävande dummies

Identifiera komplicerade grävande dummies

Komplicerat roende är det tekniska namnet som sorgproffs ger till en sorgprocess som sitter fast vid något tillfälle , vilket gör det omöjligt för de förlorade att framgångsrikt starta eller avsluta sorgprocessen. Komplicerat sorg är ofta ett tecken på olösta problem i förhållandet mellan de förlorade och den avlidne som gör det ...

Redaktörens val

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

När du har en anpassad vy för MapController i din iOS-app, måste du berätta för iPad-storyboardet att du laddar in din anpassade vy i stället för en UIViewController. Följ dessa steg: Välj Projekt navigator genom att välja Main_iPad. storyboard och välj sedan View Controller i View Controller - Map Scene i dokumentutskriften. ...

Hur man roterar objekt i din iOS-app - dummies

Hur man roterar objekt i din iOS-app - dummies

Här hittar du hur man rotera en vy (i så fall vrid bilen runt) i din iOS-app. För att göra det uppdaterar du den roterande kodstuben du startade med och ersätter den med den fetstilta koden. - (void) rotera {CGAffineTransform transform = CGAffineTransformMakeRotation (M_PI); void (^ animation) () = ^ () {self. bil. transformera = transformera; ...

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Bör du lägga till en ny anpassad vykontroll till din iOS-app innan du fortsätter till dessa steg. Du behöver fortfarande berätta för storyboardet att du vill att den ska ladda den nya anpassade vykontrollen istället för en UIViewController. Följ dessa steg:

Redaktörens val

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Adobe Creative Suite 5 (Adobe CS5) Illustrator tillåter Du sparar en grafisk stil. En grafisk stil är en kombination av alla inställningar du väljer för ett visst filter eller en effekt i Utseendepanelen. Genom att spara informationen i en grafisk stil lagras du dessa attribut så att du snabbt och enkelt kan tillämpa ...

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

I Adobe Creative Suite 5 (Adobe CS5 ) Illustratör du kan använda markeringsverktyget för att skala och rotera ett valt objekt. Dra begränsningsboxens handtag för att ändra storlek på objektet, eller flytta dig utanför ett handtag och sedan, när markören ändras till en flippig pil (en böjd pil med pilhuvud i båda ändarna), dra till ...

Objekttransformation i Adobe CS5 Illustrator - dummies

Objekttransformation i Adobe CS5 Illustrator - dummies

Verktygen Rotate, Reflect, Scale och Shear i Adobe Creative Suite 5 (Adobe CS5) Illustrator använder alla samma grundläggande steg för att utföra transformationer. Här är fem sätt att transformera ett objekt: en för en godtycklig omvandling och fyra andra för exakta omvandlingar baserat på en numerisk mängd som du anger. Vilkårlig omvandlingsmetod Eftersom detta ...