Sisällysluettelo:
- Tarvikkeet
- Vaihe 1: Määritä päämenetelmäsi
- Vaihe 2: Luo rekursiivinen menetelmäotsikko
- Vaihe 3: Luo Kicker/base Case
- Vaihe 4: Rekursiivinen vaihe
- Vaihe 5: Lyhennä ongelmaa
- Vaihe 6: Luo kokonaislukujärjestelmä
- Vaihe 7: Kutsu menetelmä joukkoosi
- Vaihe 8: Tulosta tulokset
- Vaihe 9: Onnittelut
Video: Matriisin rekursiivinen yhteenveto Javassa: 9 vaihetta
2024 Kirjoittaja: John Day | [email protected]. Viimeksi muokattu: 2024-01-30 09:00
Rekursio on erittäin hyödyllinen ja aikaa säästävä menettely, joka voi nopeasti ratkaista ongelman hyvin pienellä koodilla. Rekursio sisältää itse luomasi menetelmän, joka lyhentää alkuperäistä ongelmaa.
Tässä esimerkissä laskemme yhteen kymmenen kokonaisluvun taulukon, mutta koko voi olla minkä tahansa pituinen.
Tarvikkeet
Sinun pitäisi tuntea javan perussyntaksi ja saada IDE tai tekstieditori kirjoittaaksesi koodisi tähän tehtävään.
Vaihe 1: Määritä päämenetelmäsi
Aloita asettamalla päämenetelmäsi juuri luodulle luokalle. Olen antanut luokalleni nimen RecursiveSum. Tässä voit luoda kokonaislukuryhmän ja kutsua rekursiivisen menetelmän.
Vaihe 2: Luo rekursiivinen menetelmäotsikko
Luo päämenetelmän ulkopuolella rekursiiviselle menetelmällesi menetelmäotsikko.
Menetelmä on staattinen, koska se ei vaadi objektia sen käyttämiseen.
Palautustyyppi on int, koska käyttämämme taulukko on täynnä kokonaislukuja. Tämä voidaan kuitenkin muuttaa mihin tahansa numerotyyppiin, jota taulukko sisältää.
Olen antanut menetelmälleni recursiveSum, joka ottaa kaksi parametria; joukko kokonaislukuja ja indeksi, jonka lisäämme summaan. Olen kutsunut nämä parametrit numeroiksi ja indeksiksi.
Näet virheitä heti ja se on hyvä. Ne korjataan myöhemmin.
Vaihe 3: Luo Kicker/base Case
Rekursiivinen menetelmä tarvitsee potkurin/perustapauksen. Tämä on tila, joka estää menetelmääsi loputtomasti kutsumasta itseään. Tätä perustapausta voidaan pitää yksinkertaisimpana tapauksena, jonka kohtaamme. Tässä tapauksessa perustapaus on silloin, kun olemme ryhmämme lopussa. Jos nykyinen indeksi on yhtä suuri kuin taulukon pituus (miinus 1, koska taulukot alkavat laskea 0: sta 1: een), olemme lopussa ja palautamme kyseisen elementin kyseiselle indeksille.
Vaihe 4: Rekursiivinen vaihe
Kun meillä on perustapaus, seuraava askel on rekursiivinen vaiheemme. Tässä tapahtuu taikuutta. Olemme käsitelleet tapauksen, jossa indeksimme on taulukon viimeinen elementti. Entä jos emme ole ryhmämme viimeisessä elementissä? Entä jos voisimme yksinkertaisesti pyytää sitä lisäämään nykyisen elementtimme ja seuraavan? Lopulta saavutamme joukkomme loppuun ja peruskotelomme vaikuttaa.
Tämän saavuttamiseksi palaamme yksinkertaisesti nykyisen hakemistomme ja "lisäämme loput" taulukosta.
Vaihe 5: Lyhennä ongelmaa
Miten yksinkertaisesti "lisätään loput"? Meillä on jo menetelmä, joka lisää tietyn elementin; meidän rekursiivinenSum () -menetelmämme! Voimme kutsua sitä uudelleen, mutta muuta, mitä indeksiä laskemme yhteen.
Välitämme samassa taulukossa, jota käsittelemme, mutta välitämme seuraavan indeksin nykyisestä indeksistämme. Teemme tämän yksinkertaisesti lisäämällä yhden nykyiseen hakemistoomme kuvan mukaisesti.
Vaihe 6: Luo kokonaislukujärjestelmä
Nyt kun rekursiivinen summausmenetelmämme on valmis, voimme luoda taulukon, jota käsittelemme. Tämä taulukko on päämenetelmälohkossamme.
Voit tehdä taulukon koosta niin kauan kuin haluat. Olen luonut muutamia eri kokoja ja arvoja sisältäviä matriiseja osoittaakseni, että se ei toimi vain yhden koon kanssa.
Vaihe 7: Kutsu menetelmä joukkoosi
Nyt voit kutsua rekursiivisen menetelmän ja siirtää nämä taulukot sille. Nyt voit suorittaa ohjelman.
Vaihe 8: Tulosta tulokset
Mitään ei tapahtunut. Miksi? Rekursiivinen summa palauttaa kokonaisluvun, mutta emme ole tehneet mitään tälle kokonaisluvulle. Se teki tehtävänsä, mutta emme näe tulosta. Tuloksen saamiseksi tulostamme sen vain niin. Tämän suorittamisen jälkeen sinun pitäisi nähdä kunkin taulukon tulokset.
Vaihe 9: Onnittelut
Olet suorittanut rekursiivisen toiminnon. Voit vapaasti muuttaa matriisisi kokoa. Jos testaat sitä, huomaat sen kaatuvan, kun sinulla on tyhjä taulukko. Emme ole ottaneet sitä huomioon, mutta se on loistava tapa parantaa rekursiivista menetelmääsi.
Suositeltava:
Älykäs poiju [Yhteenveto]: 8 vaihetta (kuvilla)
Älykäs poiju [Yhteenveto]: Me kaikki rakastamme merenrantaa. Ryhmänä me keräämme sinne lomalle, nauttimaan vesiurheilusta tai ansaitsemaan toimeentulomme. Mutta rannikko on dynaaminen alue aaltojen armoilla. Merenpinnan nousu nappaa rannoilla ja voimakkaat ääritapahtumat, kuten hurri
Henkilökohtainen sääasema Raspberry Pi: n avulla BME280: n kanssa Javassa: 6 vaihetta
Henkilökohtainen sääasema Raspberry Pi: n käyttäminen BME280: n kanssa Javalla: Huono sää näyttää aina pahemmalta ikkunan läpi.Olemme aina olleet kiinnostuneita seuraamaan paikallista säätämme ja mitä näemme ikkunasta. Halusimme myös hallita paremmin lämmitys- ja ilmastointijärjestelmäämme. Henkilökohtaisen sääaseman rakentaminen on loistavaa
Yksinkertaisen laskimen tekeminen Javassa: 10 vaihetta
Yksinkertaisen laskimen tekeminen Javalla: Tämä on yksinkertainen johdanto Java -ohjelmointikielelle, joka on tarkoitettu ihmisille, joilla on vähän tai ei lainkaan ohjelmointitaitoja. eclipse.org/downloads
Kuinka käyttää silmukkaa jonon toistamiseen Javassa: 9 vaihetta
How -loopin käyttäminen taulukon toistamiseen Javassa: Tänään näytän sinulle, kuinka voit käyttää Javaa luodaksesi while -silmukan, jota voidaan käyttää toistamaan numero- tai sanaluettelo. Tämä konsepti on tarkoitettu lähtötason ohjelmoijille ja kaikille, jotka haluavat saada nopean harjoituksen Java-silmukoista ja matriiseista
Kirjoita oma Tic Tac Toe -peli Javassa: 6 vaihetta
Kirjoita oma Tic Tac Toe -peli Javalla: Olen varma, että kaikki tietävät Tic Tic Toen klassisesta pelistä. Peruskouluvuosistani lähtien Tic Tac Toe oli suosittu peli, jota pelasin ystävieni kanssa. Olen aina ollut kiinnostunut pelin yksinkertaisuudesta. Ensimmäisenä vuotena minun