Kuinka opetella itsenäistä ongelmanratkaisua?

tiedekoodari

Hei,

Mikä olisi paras tapa opetella ratkomaan ohjelmointiongelmia? Siis mieleeni ei tule juuri nyt erityistä esimerkkiä, mutta sanotaan vaikka, että olen firmassa, jossa pitäisi kehittää tavutusalgoritmi suomeen ja netti ei toimi. Tai kuinka kauan kannattaa Googlata ongelmiin muidentekemiä ratkaisuja/kirjastoja ennen kuin alkaa koodaamaan tietorakenteita, jos valmista ratkaisua ei löytynyt netistä? Olisin myös kiinnostunut, voidaanko koodia tutkia tavallaan tieteellisin menetelmin ja laskea siitä joitain metriikoita, kuinka helposti ylläpidettävää koodi on, tai todistaa, että jossain osassa koodia ei ole bugeja.

11

306

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Ajattelija .

      Itsenäisesti.

    • yxkoodaaja

      Mun mielestä yksi hyvä konsti olisi tehdä joku ohjelma tai sovellus. Siis ei mikään pieni harjoitustehtävä, vaan oikea ohjelma. Valitse joku sinua itseäsi kiinnostava aihe. Vaikka joku peli. Sen jälkeen alat rakentamaan. Ongelmia tulee taatusti eteen. Sitten mietit niihin ratkaisut ja haet verkosta esimerkkejä.

    • Lukemalla teoriaa ja tekemällä käytännössä.

      Koodin analysointityökaluja toki on, mutta virheettömyyden todistaminen on sitten haastavampaa.

    • tässä hyvä vinkki

      mene leningradin metroon ja hauku niitä.
      tai haukkumisen sijaan voit leveillä miten rikas olet.

    • ddffgdgdfg

      Tekemällä oppii. Teoriaa voi lueskella ja harjoituksiakin tehdä, mutta todellinen osaaminen tulee vain tekemällä ja tekemällä.

      Bugeja on lähes aina. Yksi apukeino on jos omaksuu testivetoisen kehittämistavan jossa testit kirjoitellaan ennen kuin varsinaista ohjelmakoodia aletaan edes tekemään. Ohjelmakoodia sitten kirjoitellaan kunnes kaikki testit menevät onnistuneesti läpi.
      http://en.wikipedia.org/wiki/Test-driven_development

    • GggKhh

      Hakeudu opiskelemaan tietojenkäsittelytiedettä oikeaan tai avoimeen yliopistoon.

    • bexjpwoeruy

      Yleensä kannattaa googlettaa noin googlettaa mahdollisimman paljon (2-10pv) verran ja tutkailla mitä ratkaisuja löytyy. Saa perspektiiviä mitenkä joku vaikea asia ratkaistaan ja hyvällä säkällä joku on ratkaissut saman ongelman huomattavasti fiksummin kuin itse olisi asian tehnyt.

      Esimerkki statiikasta:
      http://msdn.microsoft.com/en-us/library/bb385911

      Kun puhutaan ylläpidettävyydestä niin ei kannata unohtaa ohjelmointi tyyliä.
      Tähänkin on on olemassa työkaluja, esmes http://stylecop.codeplex.com/.

      Elikkä ohjelmistot testataan testi penkissä jossa on erilaisia testi tapauksia. Päästään testaamaan jotain metodia erilaisilla syötteilla. Sen lisäksi on olemassa staattisia työkaluja jotka etsii niitä bugeja. Taakin on nylyään automatisoitu eli kehitys ympäristö pyörittelee kerran päivässä 200 testiä pienellä pätkälle koodia ja ärjyilee jos ei jokin mene läpi.

      Työkaluthan riippuu täysin ohjelmointi ympäristöstä. Mutta periaatehan on sitten sama.

      Ohjelmaahan ei koskaan voida todeta teoriassa bugittomaksi. Mutta jossain vaiheessa se luovutetaan asiakkaalle ja juostasan karkuun.

      Ainiin ja algoritmien vertailuun on kehitetty teoria:
      http://en.wikipedia.org/wiki/Computational_complexity_theory

      Lyhyt johdanto suomeksi: Algoritmien aakkoset
      http://www.ohjelmointiputka.net/oppaat/

      Sekä sitten vähän vahvempana tiileskivenä.
      https://www.plazakauppa.fi/tietorakenteet-ja-algoritmit/9517627955/dp

      Ja kyllä tämmöiset perusteet pitäisi olla hallussa ennen kuin menee opiskeleen.

      • Pelle detector

        Koko juttu täyttä hölynpölyä.


      • myönteinen palaute

        Uskon että ihan hyvään suuntaan olet pyrkimässä.


      • matemaatikko82

        "Ohjelmaahan ei koskaan voida todeta teoriassa bugittomaksi."

        Ei pidä paikkaansa. Käytännössä todistaminen on hyvin työlästä mutta mahdollista: http://www.schneier.com/blog/archives/2009/10/proving_a_compu.html . En ole tutustunut juurikan laskennan teoriaan, mutta mielestäni kaikki tietokoneohjelmat voidaan simuloida äärellisellä automaatilla ja teoriassa tällainen on aina mahdollista minimalisoida ja näin saada jokaiseen ongelmaan muistin käytön suhteen optimaalinen algoritmi.


    • yksäijä

      Kyllä kai joissain jutuissa voi tehdä asioita tavallaan tieteellisesti. Esimerkiksi yrityksissä voi olla koodausstandardeja, ja standardien laatijat ovat varmaankin todistaneet, että jos tarvittavan ohjelman voi tehdä annetulla kielellä, niin sen voi tehdä myös standardien mukaan.

      Toisaalta eräässä projektissa pyydettiin etsimään virhe eräästä funktiosta. Onnistuin todistamaan, että jos kääntäjä ja käyttöjärjestelmä toimii oikein, niin funktio palauttaa aina oikean arvon. Koeta siinä sitten miettiä keinoa, millä pomon saisi antamaan enemmän vastuuta ja etsimään virhettä toisesta funktiosta.

    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Purran tuhoja tuskin saadaan koskaan korjatuksikaan

      Purra on aiheuttanut Suomen taloudelle karmaisevat tuhot. Sen lisäksi Purra on ajanut myös suuren osan Suomen kansasta k
      Maailman menoa
      121
      7435
    2. Miksi persuilla ei ole firmoja?

      Kuten vasemmisstolaisilla, esim. Sannalla MA\PI. Eikö ole aika erikoista?
      Maailman menoa
      92
      7210
    3. Persut hommasivat Suomeen 35 000 pientä lasta v. 2015

      Onko Riikka Purra nyt tavoittelemassa tätä samaa historiallista persujen utopiaa? Purram kaksinaamaisessa pelissä vaadit
      Maailman menoa
      27
      7139
    4. Marinin tuhojen korjaaminen kestää kahdeksan vuotta

      Nyt on vasta neljännes mennyt ja ensimmäiset korjausliikkeet saatu liikkeelle. Innokkaimmat olivat odottaneet että jo t
      Maailman menoa
      64
      6285
    5. Aamun Riikka: työttömyydessä lähestytään viime laman synkintä vaihetta

      Nopeasti mentiiin upean Marinin hallituksen ennätystyöllisyydestä toiseen ääripäähän, kohti Suomen historian kurjimpia t
      Maailman menoa
      3
      5734
    6. Miksette persut irtisanoudu Kirkin lausunnoista?

      Kirkhän muun muassa vaati raiskattuja naisia pidättäytymään abortista ja vaimoja alistumaan aviomiestensä tahtoon. Mik
      Maailman menoa
      97
      5628
    7. Persujen kaksoisstandardit: Räsäsen uhkailu paha, Virran uhkailu hyvä

      Tässä taas nähdään kuinka kaksinaamaista porukkaa persut ovat. Mitäs persut tähän?
      Maailman menoa
      45
      5434
    8. Demarikultin uhri kertoo

      Demarikultin uhri kertoo: “En saanut mennä edes suihkuun ilman lupaa” – Seksuaalisen hyväksikäytön uhri kertoo vuosistaa
      Maailman menoa
      65
      5275
    9. Miksi vasemmistolaiset eivät omista yhtään firmaa?

      Vasemmistolaiset eivät omista yhtään firmaa joka työllistäisi ihmisiä. Miksi? No siksi, että jos vasemmistolainen perus
      Maailman menoa
      43
      5158
    10. Sanna valittiin Euroopan huonoimmaksi pääministeriksi

      Sannan kaudella Suomi oli ainut maa missä bkt laski. Kannattaa huomata, että luvut valitsi Sannan huonoimmaksi. Ihmiset
      Maailman menoa
      27
      4656
    Aihe