Programação competitiva

Origem: Wikipédia, a enciclopédia livre.
Petr Mitrichev (à esquerda) e Gennady Korotkevich (à direita), dois proeminentes programadores competitivos durante a copa de algoritmos Yandex de 2013.

A programação competitiva ou programação esportiva é um esporte mental que envolve participantes que tentam programar de acordo com as especificações fornecidas. As competições geralmente são realizadas pela Internet ou por uma rede de área local. A programação competitiva é reconhecida e apoiada por várias empresas multinacionais de software e Internet, como o Google[1] e a Meta.[2]

Uma competição de programação geralmente envolve o anfitrião que apresenta um conjunto de problemas lógicos ou matemáticos, também conhecidos como quebra-cabeças ou desafios, aos participantes (que podem variar em número de dezenas ou mesmo centenas a vários milhares). Os participantes devem escrever programas de computador capazes de resolver esses problemas. O julgamento é baseado principalmente no número de problemas resolvidos e no tempo gasto para escrever soluções bem-sucedidas, mas também pode incluir outros fatores (qualidade do resultado produzido, tempo de execução, uso de memória, tamanho do programa etc.).

História[editar | editar código-fonte]

Um dos concursos mais antigos conhecidos é o International Collegiate Programming Contest (ICPC), que teve origem na década de 1970[3] e cresceu para incluir 88 países em sua edição de 2011.

De 1990 a 1994, Owen Astrachan, Vivek Khera e David Kotz realizaram um dos primeiros concursos de programação distribuídos e baseados na Internet, inspirado no ICPC.[4]

O interesse em programação competitiva cresceu muito desde 2000, chegando a dezenas de milhares de participantes, e está fortemente ligado ao crescimento da Internet, que facilita a realização de competições internacionais on-line, eliminando problemas geográficos.

Visão geral[editar | editar código-fonte]

O objetivo da programação competitiva é escrever o código-fonte de programas de computador capazes de resolver determinados problemas. A grande maioria dos problemas que aparecem nos concursos de programação é de natureza matemática ou lógica. Normalmente, essas tarefas pertencem a uma das seguintes categorias: combinatória, teoria dos números, teoria dos grafos, teoria dos jogos algorítmicos, geometria computacional, análise de cordas, matemática discreta e estruturas de dados.[5] Os problemas relacionados à programação por restrições e à inteligência artificial também são populares em determinadas competições.

Independentemente da categoria do problema, o processo de resolução de um problema pode ser dividido em duas etapas gerais: construção de um algoritmo eficiente e implementação do algoritmo em uma linguagem de programação adequada (o conjunto de linguagens de programação permitidas varia de acordo com o concurso). Essas são as duas habilidades mais comumente testadas em competições de programação.

Na maioria dos concursos, o julgamento é feito automaticamente por máquinas host, comumente conhecidas como juízes. Toda solução enviada por um participante é executada pelo juiz em relação a um conjunto de casos de teste (geralmente secretos). Normalmente, os problemas do concurso têm um sistema de marcação tudo-ou-nada, o que significa que uma solução é “aceita” somente se produzir resultados satisfatórios em todos os casos de teste executados pelo juiz e é rejeitada caso contrário. Entretanto, alguns problemas do concurso podem permitir pontuação parcial, dependendo do número de casos de teste aprovados, da qualidade dos resultados ou de algum outro critério especificado. Algumas outras competições exigem apenas que o competidor envie a saída correspondente aos dados de entrada fornecidos e, nesse caso, o juiz só precisa analisar os dados de saída enviados.

Os juízes on-line são ambientes on-line nos quais os testes são realizados. Os juízes on-line têm listas de classificação que mostram os usuários com o maior número de soluções aceitas e/ou o menor tempo de execução para um determinado problema.[6]

Benefícios e críticas[editar | editar código-fonte]

A participação em concursos de programação pode aumentar o entusiasmo dos alunos pelos estudos de ciência da computação. As habilidades adquiridas em concursos de programação do tipo ICPC também melhoram as perspectivas de carreira, pois ajudam a passar nas “entrevistas técnicas”, que geralmente exigem que os candidatos resolvam problemas complexos de programação e algoritmos na hora.[7][8]

Também houve críticas à programação competitiva, especialmente por parte de desenvolvedores de software profissionais.[9] Um ponto crítico é que muitos concursos de programação em ritmo acelerado ensinam aos competidores hábitos de programação e estilo de código ruins (como uso desnecessário de macros, falta de abstração e comentários de OOP, uso de nomes curtos de variáveis etc.).[10] Além disso, ao oferecer apenas pequenos quebra-cabeças algorítmicos com soluções relativamente curtas, concursos de programação como o ICPC e o IOI não ensinam necessariamente boas habilidades e práticas de engenharia de software, já que os projetos de software reais normalmente têm muitos milhares de linhas de código e são desenvolvidos por grandes equipes durante longos períodos de tempo. Peter Norvig afirmou que, com base nos dados disponíveis, o fato de ser vencedor de concursos de programação estava correlacionado negativamente com o desempenho de um programador em seu emprego no Google (embora os vencedores do concurso tivessem mais chances de serem contratados).[11] Norvig afirmou posteriormente que essa correlação foi observada em um pequeno conjunto de dados, mas que não pôde ser confirmada após o exame de um conjunto de dados maior.

Outro sentimento é que, em vez de “desperdiçar” seu tempo em competições excessivas, resolvendo problemas com soluções conhecidas, os programadores de alto nível deveriam investir seu tempo na solução de problemas do mundo real.[9]

Literatura[editar | editar código-fonte]

  • Halim, S., Halim, F. (2013). Competitive Programming 3: The New Lower Bound of Programming Contests. Lulu.
  • Laaksonen, A. (2017). Guide to Competitive Programming (Undergraduate Topics in Computer Science). Cham: Springer International Publishing.
  • Xu, X. (2020) The development, prosperity and decline of Olympic in Informatics. Publicado online.
  • Kostka, B. (2021). Sports programming in practice. Universidade de Wrocław.

Ver também[editar | editar código-fonte]

Referências

  1. «TCO12 Sponsor: Google | TCO 12». web.archive.org. 16 de fevereiro de 2012. Consultado em 9 de maio de 2024 
  2. «Entre ou cadastre-se para visualizar». www.facebook.com. Consultado em 9 de maio de 2024 
  3. Li, Yujia; Choi, David; Chung, Junyoung; Kushman, Nate; Schrittwieser, Julian; Leblond, Rémi; Eccles, Tom; Keeling, James; Gimeno, Felix (9 de dezembro de 2022). «Competition-level code generation with AlphaCode». Science (em inglês) (6624): 1092–1097. ISSN 0036-8075. doi:10.1126/science.abq1158. Consultado em 9 de maio de 2024 
  4. Khera, Vivek; Astrachan, Owen; Kotz, David (março de 1993). «The internet programming contest: a report and philosophy». ACM SIGCSE Bulletin (em inglês) (1): 48–52. ISSN 0097-8418. doi:10.1145/169073.169105. Consultado em 9 de maio de 2024 
  5. «Math 182 (Summer 2022)». www.math.ucla.edu. Consultado em 9 de maio de 2024 
  6. Skiena, Steven S. (2003). Programming challenges : the programming contest training manual. Internet Archive. [S.l.]: New York : Springer 
  7. https://people.cs.uchicago.edu/~borja/pubs/sigcse2016-programming-contests.pdf
  8. https://static.googleusercontent.com/media/research.google.com/en//pubs/archive/41881.pdf
  9. a b Smith, Duncan (2 de dezembro de 2015). «The Competitive Programming Debate». Red-Green-Code (em inglês). Consultado em 9 de maio de 2024 
  10. «World of Seven - CS3233 - Competitive Programming». www.comp.nus.edu.sg. Consultado em 9 de maio de 2024 
  11. Winning at programming competitions is a negative factor for being good on the job, consultado em 9 de maio de 2024