Konkurencingas programavimas pradedantiesiems: „Topcoder“ iššūkiai

Turinys:

Anonim

Kas yra konkurencingas programavimas?

Konkurencinis programavimas yra kodavimo problemų sprendimas naudojant algoritmą ir duomenų struktūrą. Dalyviams reikia rašyti kodą pagal įvairius apribojimus, pvz., Atminties apribojimus, vykdymo laiką, kodavimo limitą, erdvę ir kt.

Nugalėtojas paskelbiamas remiantis išspręstomis problemomis ir laiku, skirtu sėkmingų programavimo sprendimų rašymui. Tačiau tai taip pat apima kitus veiksnius, tokius kaip pagamintos produkcijos kokybė, vykdymo laikas, programos dydis ir kt.

Šioje pamokoje sužinosite

  • Kas yra konkurencingas programavimas?
  • Konkurencinio programavimo egzamino nauda
  • Konkurencinio programavimo istorija
  • Įgūdžių patikrinimas konkurenciniuose programavimo egzaminuose
  • Kaip pradėti?
  • Kaip pasirengti konkurencingam programavimui?
  • Konkurencingo programavimo mitai ir realybė
  • Geriausia konkurencinių kodavimo egzaminų praktika
  • Konkurencingo programavimo trūkumai

Konkurencingo programavimo nauda

Čia yra dalyvavimo varžybose pranašumai:

  • Konkurencingas programavimas padeda tobulinti loginius ir analitinius įgūdžius
  • Tai pagerina jūsų algoritmines žinias.
  • Tai puikus jūsų CV papildymas.
  • Patobulinkite savo draugų tinklą, kurie taip pat aistringai užsiima programavimu
  • Ją palaiko garsios pasaulio organizacijos, tokios kaip „Google“, „Amazon“, „Facebook“, IBM ir kitos.

Konkurencinio programavimo istorija

Konkurencingų programų pasaulyje seniausias konkursas yra ACM-ICPC (tarptautinis kolegialaus programavimo konkursas). Jis atsirado 1970-aisiais ir išaugo iki 88 šalių.

Po 2000 m. Susidomėjimas programavimo iššūkiais labai išaugo. Tai buvo įmanoma dėl interneto augimo. Tai leidžia koduoti konkursų svetaines rengti tarptautinius konkursus internete.

Įgūdžiai, reikalingi konkurencinio programavimo egzaminuose

Įgūdis Išsami informacija
Svarbūs įgūdžiai
  • Algoritmo įgūdžiai
  • Pagrindiniai matematikos įgūdžiai
  • Programavimo įgūdžiai
  • Rašyti greičio įgūdžius
  • Derinimo įgūdžiai
Užbaigti paiešką
  • Žiaurios jėgos paieška naudojant visą paieškos erdvę
  • Laiko limito peržengimas
  • Paieškos optimizavimas
Skaldyk ir užkariauk
  • Kodavimo problemos padalijimas į mažesnes dalis
  • Dvejetainė paieška
Dinaminis programavimas
  • Nustatykite probleminę būseną
  • Greitesnis ir sudėtingesnis rekursinis grįžimas

Kaip pradėti?

Štai keletas naudingų patarimų, kuriuos turėtumėte žinoti prieš pradėdami naudoti konkurencingą programavimą:

  • Labai svarbu pasirinkti programavimo kalbą, kuri jums patogiausia
  • Prisiregistruokite bet kurioje interneto kodavimo iššūkio svetainėje ir pradėkite spręsti jų praktikos problemas
  • Turite sužinoti apie duomenų struktūras, kurios yra gyvybiškai svarbios sprendžiant sudėtingus kodavimo klausimus.
  • Turite suprasti programų sudėtingumo sampratą.
  • Sužinokite apie svarbius programavimo modelius, tokius kaip rekursija, dinaminis programavimas ir kt.

Geriausios konkurencingos programavimo svetainės

Svarbiausios geriausios kodavimo iššūkio vietos yra šios:

  • „TopCoder“
  • Coderbyte
  • Kodekarai
  • CodeChef
  • Bendrosios jėgos
  • Hackerearthas

„Topcoder“:

„Topcoder“ yra plačiai populiari konkurencingo programavimo platforma. Tai siūlo daugybę algoritminių iššūkių, kuriuos galite atlikti patys naudodami jų kodo rengyklės įrankį. Svetainė labiau tinka pažengusiai auditorijai.

Apsilankykite čia: https://www.topcoder.com/

Coderbyte

„Coderbyte“ siūlo daugiau nei 200 įvairių tipų kodavimo uždavinių, kuriuos galite išspręsti internetiniame redaktoriuje naudodami 10 skirtingų programavimo kalbų. Ji teikia oficialius sprendimus ir daugiau nei 800 000 vartotojų sukurtų sprendimų.

Apsilankykite čia: https://coderbyte.com/

Kodekarai

„Codewars“ siūlo platų kodavimo iššūkių rinkinį. Galite pateikti savo iššūkius, kuriuos redaguos bendruomenė. Tai leidžia jums išspręsti šiuos iššūkius internetu, naudojant jų redaktorių iš daugiau nei 20 programavimo kalbų.

Apsilankykite čia: https://www.codewars.com/

CodeChef

„CodeChef“ siūlo šimtus konkurencingų programavimo iššūkių. Tai leidžia jums parašyti kodą jų internetiniame redaktoriuje ir peržiūrėti iššūkių rinkinį. Kodavimo problemos yra suskirstytos į skirtingas kategorijas pagal jūsų įgūdžių lygį.

Apsilankykite čia: https://www.codechef.com/

Bendros jėgos

„Codeforces“ yra Rusijos bazės konkurencingo programavimo svetainė. Jis reguliariai rengia kodavimo konkursą, kuriame dalyvauja konkurencingi programuotojai iš viso pasaulio.

Apsilankykite čia: https://codeforces.com/

Hackerearthas:

„HackerEarth“ siūlo įmonės programinės įrangos sprendimus. Tai padeda įmonėms ar asmenims patenkinti jų inovacijų valdymą ir techninius įdarbinimo poreikius. „HackerEarth“ iki šiol atliko daugiau nei 10 000 programavimo iššūkių.

Apsilankykite čia: https://www.hackerearth.com/

Konkurencingo programavimo mitai ir realybė

Mitai Realybė
Pradėti konkurencingą programavimą jau per vėlu Nėra nustatyto amžiaus, kada geriausia pradėti anksčiau jūsų programavimo karjeroje.
Tai puikus būdas gauti programinės įrangos programavimo darbą Ne, tai netiesa, nes tai yra sportas, kuris gali būti naudingas. Tačiau tai nesuteikia darbo garantijos.
Prieš pradėdami konkurencingą programavimą, turite išspręsti daugybę skaičiavimo programų. Galite išmokti teorijos, tačiau išspręsti skaičiavimo uždavinius nepadėsite, nes kiekvienas konkursas yra unikalus su savo unikaliais iššūkiais.
Jums reikia algoritmo eksperto Turite mokėti išspręsti problemas
Konkurencingi programuotojai yra patyrę programuotojai. Ne, visiems gali dalyvauti net pradedančiųjų kodas
Tai tik pomėgis ar žaidimas Konkurencinis programavimas, priešingai, apima tuos pačius įgūdžius, kurie mokomi informatikos mokymo programoje, tačiau daug giliau. Taigi, to negalima pavadinti žaidimu.

Geriausia konkurencinių kodavimo egzaminų praktika

Nors nėra fiksuotos taisyklės, vis dėlto geriausia praktika, kurios turėtumėte laikytis:

  • Pabandykite išmokti naujų ir efektyvių algoritmų ir prireikus juos įdiegti.
  • Gerai išmanyti duomenų struktūras, tokias kaip sąrašai, medžiai ir grafikai
  • Perskaitykite privatumo informaciją iš konkurencingo programavimo svetainės ir susisiekite su jais prieš prisiregistruodami.
  • Turėtumėte pasirinkti problemą, kuriai galite rasti sprendimą ir galbūt paaiškinimą.
  • Parašykite problemos bandymo atvejus ir prieš pateikdami patikrinkite savo logiką naudodami tuos bandymo atvejus.
  • Turite išlaikyti iš anksto parašytus standartinių algoritmų šablonus, būtinas antraštes, funkcijas ir kt.
  • Naudokite funkcijas / metodus ir sumažinkite kodo pasikartojimą.
  • Išbandykite kodą blogiausio atvejo atveju ir pabandykite išsiaiškinti geriausią šios situacijos sprendimą

Konkurencingo programavimo trūkumai

  • Klaida dėl blogų įvesties problemų yra sunku derinti.
  • Jūs taip įpratote prie mažų atlygių ir trumpalaikių tikslų. Realiame gyvenime dirbant prie bet kurio projekto dažniausiai užtrunka du tris mėnesius, kol gausite atlygį už projektą, kuriame dirbate
  • Tikriausiai tapsite kodavimo meistru, bet nežinosite jokių sistemų (svarbių realiems projektams)
  • Dalyvauti yra daug laiko ir nuobodu, ir tai reikia daryti pakartotinai.

Santrauka

  • Konkurencinis programavimas yra kodavimo problemų sprendimas naudojant algoritmą ir duomenų struktūrą.
  • Kodavimo konkursai padeda tobulinti loginius ir analitinius įgūdžius.
  • ICPC atsirado 1970-aisiais ir išaugo iki 88 šalių.
  • Konkurenciniuose programavimo egzaminuose reikalingi algoritmo įgūdžiai, pagrindiniai matematikos įgūdžiai, programavimo įgūdžiai, rašymo greitis.
  • Labai svarbu pasirinkti programavimo kalbą, kuri jums patogiausia
  • Svarbiausios geriausios kodavimo iššūkio vietos yra: 1) „TopCoder“ 2) „Coderbyte“ 3) „Codewars“ 4) „CodeChef“ 5) „Codeforce“ 6) „Hackerearth“.
  • Paplitęs mitas, kad pradėti konkuruoti programuoti yra per vėlu. Tačiau realybė yra ta, kad tam nėra nustatyto amžiaus.
  • Geros konkurencinių kodavimo egzaminų geriausios praktikos pavyzdžiai yra geros duomenų struktūrų, tokių kaip sąrašai, medžiai ir grafikai, išmanymas.