સ્પર્ધાત્મક પ્રોગ્રામિંગ

વિકિપીડિયામાંથી
યાન્ડેક્સ પર Algorithm નામની એક ઓપન હરીફાઈ. ઓગસ્ટ 22, 2013.

સ્પર્ધાત્મક પ્રોગ્રામિંગ એક માનસિક રમત છે જે સામાન્ય રીતે ઈન્ટરનેટ અથવા સ્થાનિક નેટવર્ક પર યોજાય છે, જેમાં સ્પર્ધકોને આપેલ શરતો (કે વર્ણન) મુજબનો પ્રોગ્રામ બનાવવાનો હોય છે. આ સ્પર્ધકોને રમતવી11ર પ્રોગ્રામર કહે છે. Google,[૧][૨] Facebook[૩] and IBM[૪] જેવી ઘણી બહુરાષ્ટ્રીય સોફ્ટવેર અને ઈન્ટરનેટ કંપનીઓ દ્વારા સ્પર્ધાત્મક પ્રોગ્રામિંગને ઓળખવામાં આવે છે અને આધાર આપવામાં આવે છે. ઘણી સંસ્થાઓ (વેબસાઈટો) નિયમિતપણે આવી પ્રોગ્રામિંગ સ્પર્ધાઓ યોજે છે.

પ્રોગ્રામિંગ સ્પર્ધામાં સામાન્ય રીતે યજમાન તાર્કિક કે ગાણિતિક કોયડાઓ સ્પર્ધકો (જેમની સંખ્યા ૧૦થી હજારો હોઈ શકે) સમક્ષ રજુ કરે છે, અને સ્પર્ધકોએ દરેક કોયડો ઉકેલી શકતો કમ્પ્યુટર પ્રોગ્રામ લખવાનો હોય છે. તેમાં ઉકેલેલ કોયડાઓની સંખ્યા અને સફળ ઉકેલ લખવામાં લાગેલા સમય પરથી સામાન્ય રીતે ચુકાદો અપાય છે, પરંતુ ક્યારેક અન્ય પરીબળ (જેમ કે આઉટપૂટની ગુણવત્તા, પ્રોગ્રામને ચાલવામાં લાગેલો સમય, પ્રોગ્રામનું કદ વગેરે)ને પણ ધ્યાનમાં લેવાતાં હોય છે.

ઈતિહાસ[ફેરફાર કરો]

સૌથી જૂની જ્ઞાત સ્પર્ધાઓમાં એક ACM ICPC છે જે ૧૯૭૦ના દાયકામાં શરુ થઇ હતી, અને ૨૦૧૧ સુધીમાં ૮૮ દેશોમાં પ્રસરી છે. ઈ.સ. ૨૦૦૦ની સાલથી સ્પર્ધાત્મક પ્રોગ્રામિંગમાં રસ દાખવવાનું વલણ બહુ વધ્યું છે, જેનો ઈન્ટરનેટના વિકાસ સાથે ઊંડો સંબંધ છે, જે ભૌગોલિક પ્રશ્નોને દૂર કરીને, ઓનલાઈન આંતરરાષ્ટ્રીય સ્પર્ધાઓ ગોઠવવામાં મદદરૂપ થાય છે.

સામાન્ય પરિચય[ફેરફાર કરો]

સ્પર્ધાત્મક પ્રોગ્રામિંગનો ધ્યેય, આપેલા કોયડાઓને ઉકેલી શકે તેવા કમ્પ્યુટર પ્રોગ્રામનો સોર્સ કોડ લખવાનો હોય છે. પ્રોગ્રામિંગ સ્પર્ધાઓમાં આવતાં કોયડાઓ માંથી મોટા ભાગના કોયડાઓ (સ્વભાવે) ગાણિતિક કે તાર્કિક હોય છે. તેવા કોયડાઓ લાક્ષણિક રીતે નીચેનામાંથી કોઈ એક વર્ગના હોય છે: ક્રમચય-સંચયનું વિજ્ઞાન, અંક સિદ્ધાંત, ગ્રાફ સિદ્ધાંત, ભૂમિતિ, લખાણ (સ્ટ્રીંગ)નું વિશ્લેષણ and માહિતી માળખાં . કેટલીક સ્પર્ધાઓમાં કૃત્રિમ બુદ્ધિમત્તાને લગતાં કોયડા પણ પ્રચલિત છે.

કોયડાના પ્રકાર (વર્ગ)થી નિરપેક્ષ રીતે, કોયડા ઉકેલવાની પ્રક્રિયા મુખ્યત્વે બે ભાગોમાં વિભાજીત કરી શકાય, ૧) એક કાર્યક્ષમ અલગોરિધમની રચના, અને ૨) તે અલગોરિધમને કોઈ એક અનુકુળ પ્રોગ્રામિંગ ભાષામાં અમલમાં મૂકવો. (જૂદી જૂદી સ્પર્ધાઓમાં જૂદી જૂદી પ્રોગ્રામિંગ ભાષાઓ માન્ય હોય છે.) આ બે સ્કીલ્સ પ્રોગ્રામિંગ સ્પર્ધાઓમાં સર્વસામાન્ય રીતે ચકાસાતી હોય છે.

મોટાભાગની સ્પર્ધાઓમાં યોજનાર કમ્પ્યુટર (સર્વર) (જેમને જજ કહે છે) દ્વારા સ્વયંસંચાલિત રીતે નિર્ણયો અપાય છે. સ્પર્ધક દ્વારા અપાયેલ દરેક ઉકેલને જજ વિવિધ (સામાન્ય રીતે ગુપ્ત) 'ચકાસણી કેસ' માટે ચકાસે છે. સામાન્ય રીતે, સ્પર્ધાઓમાં બધા-અથવા-એકે નહી ગુણ-પ્રણાલિ હોય છે, એટલે કે કોઈ ઉકેલ તો જ "સ્વીકાર" થાય છે જો તે જજ દ્વારા ચલાવતાં બધા જ test કેસમાં સાચો ઉત્તર આપે, અન્યથા તે ઉકેલ ખોટો ગણાય છે. પરંતુ, કેટલીક સ્પર્ધાઓમાં આંશિક ગુણ માન્ય હોય છે, જેના માટે પાસ કરેલ test કેસની સંખ્યા, પરિણામોની ગુણવત્તા, અથવા અન્ય કોઈ ખાસ માપદંડ હોય છે. કેટલીક સ્પર્ધાઓમાં સ્પર્ધકે માત્ર આપેલ ઈનપુટ માહિતીને અનુરૂપ આઉટ્પુટ માહિતી આપવાની હોય છે, જેમાં જજ માત્ર આઉટ્પુટ માહિતી જ ચકાસે છે.

નોંધપાત્ર સ્પર્ધાઓ[ફેરફાર કરો]

સ્પર્ધાઓ બે પ્રકારની હોય છે: ટૂંકાગાળાની અને લાંબાગાળાની. ટુંકા ગાળાની સ્પર્ધાઓનો પ્રત્યેક રાઉન્ડ ૧-૩ કલાકનો હોય છે. લાંબા ગાળાની સ્પર્ધાઓ થોડા દિવસોથી માંડીને થોડા મહિનાઓ સુધી ચાલતી હોય છે.

ટુંકા ગાળાની સ્પર્ધાઓ[ફેરફાર કરો]

  • ACM ICPC - વિશ્વની સૌથી જૂની સ્પર્ધાઓમાંની એક, જે કૉલેજના વિદ્યાર્થીઓના માટે હોય છે, અને તેમાં ૩ના ગ્રુપમાં ભાગ લઇ શકાય છે. આ સ્પર્ધાની પુરસ્કર્તા IBM કંપની છે.
  • ACSL - માધ્યમિક કે ઉચ્ચતર માધ્યમિક શાળાના વિદ્યાર્થીઓ માટેની કમ્પ્યુટર વિજ્ઞાન સ્પર્ધા, જેમાં લેખિત અને પ્રોગ્રામિંગ વિભાગો હોય છે.
  • CodeChef Cook-Off[૫] - ACM ICPC જેવી પ્રોગ્રામીંગ સ્પર્ધા, જે દર મહિનાના છેલ્લેથી બીજા રવિવારે હોય છે.
  • CodeChef LunchTime[૫] - એક જુનિયર પ્રોગ્રામિંગ શ્રેણી (સ્પર્ધા) જે દર મહિનાના છેલ્લા રવિવારે હોય છે, જે માધ્યમિક કે ઉચ્ચતર માધ્યમિક શાળાના વિદ્યાર્થીઓ માટે હોય છે.
  • CodeChef SnackDown[૬] - CodeChef દ્વારા યોજાતી વાર્ષિક બહુ-રાઉન્ડ, વૈશ્વિક પ્રોગ્રામિંગ સ્પર્ધા
  • Facebook Hacker Cup - 2011થી યોજાતી વાર્ષિક સ્પર્ધા, જેની યોજનાર અને પુરસ્કર્તા Facebook કમ્પની છે.
  • Google Code Jam - 2003થી યોજાતી સ્પર્ધા, જેનું યોજનાર અને પુરસ્કર્તા Google છે.
  • HackerRank Ad Infinitum[૭] - HackerRank દ્વારા આયોજિત ગણિત પ્રોગ્રામિંગ સ્પર્ધા
  • HackerRank Week of Code[૮] - HackerRank દ્વારા આયોજિત ૭ દિવસની સ્પર્ધા
  • ICFP Programming Contest - 1998 થી આંતરરાષ્ટ્રીય ઉપયોગી પ્રોગ્રામીંગ સભા (the International Conference on Functional Programming) દ્વારા યોજાતી સ્પર્ધા.
  • IEEEXtreme Programming Competition - 2006 થી IEEE દ્વારા યોજાતી સ્પર્ધા
  • IOI - માધ્યમિક શાળાઓના વિદ્યાર્થીઓ માટે યોજાતી સૌથી જૂની સ્પર્ધાઓમાંની એક.
  • TopCoder Open - Algorithm - TopCoder દ્વારા ૨૦૦૪થી યોજાતી સ્પર્ધા.

મોટા ભાગની ઉપર્યુક્ત સ્પર્ધાઓમાં સ્પર્ધકોની સંખ્યા બહુ મોટી હોવાથી, સ્પર્ધા સામાન્ય રીતે ઘણા રાઉન્ડમાં યોજાય છે. તેમાં છેલ્લા રાઉન્ડ સિવાયના બધા જ રાઉન્ડ ઓનલાઈન હોય છે, જ્યારે છેલ્લો રાઉન્ડ ઓફલાઈન હોય છે. આમાં એક અપવાદ IEEEXtreme છે, જે એક વાર્ષિક, 24-કલાકની ઓનલાઈન સ્પર્ધા છે. IOI અને ACM ICPC ના વિજેતાઓને સ્વર્ણ, રજત અને કાંસ્ય ચંદ્રક મળે છે, જ્યારે અન્ય સ્પર્ધાઓમાં વિજેતાઓને રોકડ ઇનામ અપાય છે. વધુમાં, આવી સ્પર્ધાઓના સ્કોર ટેબલમાં ઉચ્ચ સ્થાન મેળવવાથી ઘણી સોફ્ટવેર અને ઈન્ટરનેટ કંપનીઓનું ધ્યાન આકર્ષિત કરી શકાય છે.

લાંબા-ગાળાની સ્પર્ધાઓ[ફેરફાર કરો]

  • CodeChef Long Challenges[૫]
  • Google AI Challenge
  • Kaggle
  • TopCoder Marathon matches

ઓનલાઇન સ્પર્ધાઓ અને તાલીમ મેળવવાના સ્ત્રોતો[ફેરફાર કરો]

જગતભરના પ્રોગ્રામરોનો સમૂહ સ્પર્ધાત્મક પ્રોગ્રામિંગને સમર્પિત ઘણા ઈન્ટરનેટ-સ્રોતો (વેબ્સાઈટો) સર્જ્યા છે અને જાળવે છે. તેઓ નાના ઇનામો વાળી કે ઇનામ વિનાની છૂટક સ્પર્ધાઓ યોજે છે. વધુમાં, સ્પર્ધાત્મક પ્રોગ્રામિંગની તાલીમ માટેનો એક પ્રચલિત સ્રોત જૂના કોયડાઓનો સંગ્રહ પણ હોય છે. તેમાં નીચેનાનો સમાવેશ થાય છે:

similarweb અનુસાર ક્રમાંક નામ વર્ણન ACM/ICPC
5808[૯] HackerRank (હેકર-રેન્ક) "સૌથી વધુ સર્જનશીલ" સ્પર્ધાત્મક પ્રોગ્રામિંગ વેબ્સાઈટ. તે 2012માં શરુ કરાઈ હતી, અને સંગણક વિજ્ઞાનના જૂદા જૂદા ક્ષેત્રોમાં કોયડાઓ ધરાવે છે. તે વાર્ષિક Codesprints પણ યોજે છે, જેનાથી પ્રોગ્રામરો સીધા સીલીકોન વેલીની નવ-પ્રારંભ કંપનીઓ (સ્ટાર્ટ-અપ) સાથે જોડાઈ શકે. hackerrank.com
12181[૧૦] GeeksforGeeks (ગીક્સ ફોર ગીક્સ) લેખો અને મહાવરા માટે પ્લેટફોર્મ ધરાવતી એક વેબસાઈટ. આ સાઈટ મુખ્યત્વે પ્રોગ્રામિંગ મૌખિક પરીક્ષા(ઇન્ટરવ્યુ)ની તૈયારી માટે છે. તે 2009માં શરુ થઇ હતી અને તેમાં સ્પર્ધાત્મક પ્રોગ્રામિંગ પ્લેટફોર્મ 2015 માં શરુ કરાયું હતું. geeksforgeeks.org
17667[૧૧] Codeforces (કોડ-ફોર્સીસ) રશિયન સ્ત્રોત, સરતોવ રાજ્ય વિદ્યાપીઠ (Saratov State University) દ્વારા સંચાલિત, જે નિયમિત રીતે (દર અઠવાડિયે ૨ વખત) ટૂકી સ્પર્ધાઓ પૂરી પાડે છે. વિશેષ ખૂબીઓ: અન્ય સ્પર્ધકોના ઉકેલોની સત્યતા "કોડીંગ સમયે" ચકાસી શકાય, આભાસી સ્પર્ધાઓ, તાલીમ વગેરે. codeforces.com
27074[૧૨] CodeChef (કોડ-શેફ) Directi દ્વારા સંચાલિત, જે એક 10-દિવસ-લાંબી સ્પર્ધા અને ૨ ટૂંકી સ્પર્ધાઓ દર મહીને યોજે છે (એક IOI જેવી અને બીજી ACM ICPC જેવી), અને શૈક્ષણિક સંસ્થાઓને મફતમાં સ્પર્ધા યોજવાનું પ્લેટફોર્મ પૂરું પાડે છે. લાંબી સ્પર્ધાના ટોપ બે વિજેતાઓને રોકડ ઇનામ જ્યારે વૈશ્વિક ટોપ ૧૦ ને ટીશર્ટ અપાય છે. www.codechef.com
28109[૧૩] TopCoder (ટોપ-કોડર) અમેરિકાનો સ્ત્રોત અને કમ્પની, જે સ્પર્ધાઓ યોજે છે અને free-lance નોકરી તરીકે ઔદ્યોગિક પ્રશ્નો પણ પૂરા પાડે છે; તે ડઝનો ટૂકી સ્પર્ધાઓ અને ઘણી લાંબી ("મેરાથોન") સ્પર્ધાઓ દર વર્ષે યોજે છે. ખાસ ખૂબીઓ - અન્ય સ્પર્ધકોના ઉકેલોની સત્યતા કોડીંગ પછી અને અંતિમ સ્વયંસંચાલિત ચકાસણી (ચેલેન્જ ફેઝ) પૂર્વે ચકાસી શકાય. www.topcoder.com
31587[૧૪] Project Euler (પ્રોજેક્ટ યુલર) ગણતરીવાળા ગણિત કોયડાઓનો મોટો સંગ્રહ (એટલે કે પ્રોગ્રામિંગ સાથે સીધું જ સંલગ્ન નથી, પણ ઘણે ભાગે પ્રોગ્રામિંગની જરૂર પડે છે). projecteuler.net
37853[૧૫] CodinGame (fr

) (કોડીન્ગેમ)

કોયડાઓ (વધતી જટિલતાવાળા), કોડ ગોલ્ફ. નિયમિત રીતે ઓનલાઈન સ્પર્ધાઓ યોજે છે (કૃત્રિમ બુદ્ધિમત્તાના પ્રશ્નો, ઇષ્ટતમ બનાવવાના (ઓપ્ટીમાઈઝેશનના) પ્રશ્નો) www.codingame.com
32843[૧૬] HackerEarth (હેકર-અર્થ) Bangalore, India સ્થિત કંપની જે ઓનલાઈન સ્પર્ધા જેવું વાતાવરણ, નોકરીએ રાખવાની કસોટી માટેના હેતુથી પૂરું પાડે છે. www.hackerearth.com
45824[૧૭] SPOJ (સ્પોજ) પોલેન્ડની ઓનલાઈન જજ પ્રણાલિ જે તાલીમ માટે ઘણા પ્રશ્નો પૂરા પાડે છે, અને અન્ય આયોજકોને તેમની પ્રોગ્રામિંગ સ્પર્ધા યોજવા માટે આધાર પૂરો પાડે છે. www.spoj.com
49763[૧૮] POJ (પોજ) ACM/ICPC માટે પેકિંગ વિશ્વવિદ્યાલય (Peking University)નું ઓનલાઈન જજ, જે Ying Fuchen, Xu Pengcheng અને Xie Di એ બનાવ્યું હતું. 3,055 કોયડાઓ ધરાવે છે. www.poj.org
125102 UVa Online Judge (યુવા ઓનલાઈન જજ) મહાવરા માટે ૩૫૦૦+ કોયડા ધરાવે છે. નિયમિત રીતે ઓનલાઈન સ્પર્ધાઓ યોજે છે. uva.onlinejudge.org
172157 Coderbyte (કોડર-બાઈટ) પ્રોગ્રામિંગ કોયડા ધરાવે છે, જે તમે એક ઓનલાઈન એડિટરમાં ૯ પ્રોગ્રામિંગ ભાષાઓમાંથી કોઈ એકમાં લખી શકો. એ ઉપરાંત અલગોરિધમ ના શૈક્ષણિક વિડીઓ, પ્રાથમિક JavaScript કોર્ષ, વિડીઓ ટુટોરીયલ્સ, અને નોકરી માટેની મૌખિક કસોટીની તૈયારી કરવાના મટીરીયલ. www.coderbyte.com

આ પણ જૂઓ:[ફેરફાર કરો]

  • કોડ ગોલ્ફ

References[ફેરફાર કરો]

  1. "Google Code Jam" સંગ્રહિત ૨૦૧૬-૦૨-૧૯ ના રોજ વેબેક મશિન. google.com.
  2. "TCO12 Sponsor: Google - TCO 12". topcoder.com.
  3. "Facebook Hacker Cup".
  4. "ACM International Collegiate Programming Contest World Finals Sponsored by IBM". મૂળ માંથી 2016-03-10 પર સંગ્રહિત. મેળવેલ 2016-10-01.
  5. ૫.૦ ૫.૧ ૫.૨ "COMPETE - CodeChef". codechef.com.
  6. "Snackdown Home - CodeChef". codechef.com. 
  7. "Programming problems and Competitions :: HackerRank".
  8. "Programming problems and Competitions :: HackerRank".
  9. "Security Screen". www.similarweb.com.
  10. "Security Screen". www.similarweb.com.
  11. "Security Screen". www.similarweb.com.
  12. "Security Screen". www.similarweb.com.
  13. "Security Screen". www.similarweb.com.
  14. "Security Screen" સંગ્રહિત ૨૦૧૫-૧૦-૨૦ ના રોજ વેબેક મશિન. www.similarweb.com.
  15. "Security Screen" સંગ્રહિત ૨૦૧૬-૦૯-૧૮ ના રોજ વેબેક મશિન. www.similarweb.com.
  16. "Security Screen" સંગ્રહિત ૨૦૧૫-૧૧-૧૭ ના રોજ વેબેક મશિન. www.similarweb.com.
  17. "Security Screen" સંગ્રહિત ૨૦૧૫-૧૨-૧૧ ના રોજ વેબેક મશિન. www.similarweb.com.
  18. "Security Screen" સંગ્રહિત ૨૦૧૬-૦૬-૦૨ ના રોજ વેબેક મશિન. www.similarweb.com.

બાહ્ય કડીઓ[ફેરફાર કરો]

સ્પર્ધાઓ યોજવા માટે મુક્ત-સ્ત્રોત સોફ્ટવેર
  • Contest Management System Open-source tool in Python to run and manage a programming contest on a server IOI 2012 and IOI 2013.