Por qué Leetcode está obsoleto y la programación en pareja para las entrevistas es el camino a seguir

Rate this content
Bookmark

Todos hemos experimentado la solicitud de empleo que nos obliga a realizar una prueba de codificación en línea. Tienes que repasar tus algoritmos, estructuras de datos, complejidad temporal y al final estás estudiando como si fuera un examen universitario. Ahora que somos nosotros los que generalmente entrevistamos a los candidatos, una buena pregunta para hacer es: "¿las pruebas de codificación en línea son el mejor indicador de la competencia y habilidad de un candidato?" En esta charla, exploraremos:

  • - Los problemas de las pruebas similares a Leetcode

  • - Lo que deberíamos buscar en los candidatos

  • - Cómo la programación en pareja es la mejor manera de ver cómo un candidato trabajaría con el equipo

  • - Además, una pequeña demostración de una entrevista de programación en pareja remota




This talk has been presented at TechLead Conference 2023, check out the latest edition of this Tech Conference.

FAQ

Las pruebas de codificación en línea se critican por enfocarse principalmente en algoritmos y estructuras de datos bajo presión de tiempo, lo cual no refleja las habilidades necesarias en el día a día de los roles de desarrollo de software.

La programación en pareja durante las entrevistas permite evaluar las habilidades prácticas de los candidatos en un escenario más realista y colaborativo, ayudando a determinar cómo se integrarían en el equipo.

Un proceso de entrevista bien estructurado ayuda a mejorar la calidad del equipo, protege la reputación de la empresa y reduce los costos asociados con la contratación y eventual recontratación.

Se busca que los candidatos sean capaces de escribir un código que sea mantenible, comprensible y eficiente, refutando la idea del desarrollador '10X' que es altamente productivo pero poco realista.

Las pruebas en línea tienden a medir conocimientos sobre algoritmos y estructuras de datos, lo cual no siempre se alinea con las habilidades requeridas en el día a día de un desarrollador.

La programación en pareja es un método de entrevista donde el entrevistador y el candidato trabajan juntos en un problema de codificación usando un entorno realista, lo que proporciona una evaluación más precisa de las habilidades prácticas del candidato.

Muhammad recomienda conocer al candidato antes de empezar la entrevista técnica, revisar la solución conjuntamente al final y pedir feedback para mejorar el proceso de entrevistas.

Mo Khazali
Mo Khazali
32 min
09 Mar, 2023

Comments

Sign in or register to post your comment.
Video Summary and Transcription
La charla analiza los problemas con las pruebas de codificación en línea y los beneficios de las entrevistas de programación en pareja. Se enfatiza la importancia de la contratación y el crecimiento, incluyendo la creación de una experiencia de entrevista positiva y considerando el costo de la contratación. El trabajo de un desarrollador de software va más allá de la codificación y requiere múltiples conjuntos de habilidades. La programación en pareja proporciona una evaluación más precisa de las habilidades requeridas para el desarrollo de software. La charla también cubre la implementación de un sistema de puntuación de tenis y la personalización de las entrevistas de programación en pareja para diferentes roles y niveles.

1. Introduction to Hiring and Growth

Short description:

Hola a todos. Hoy discutiremos los problemas con las pruebas de codificación en línea, los beneficios de las entrevistas de programación en pareja y la importancia de la contratación y el crecimiento. También exploraremos las características ideales del candidato y la falta de coincidencia entre las plataformas de codificación en línea y las habilidades requeridas. Compartiré mi experiencia personal con las entrevistas de programación en pareja y su impacto en mi carrera. Comencemos.

♪♪ Hola a todos. Estoy muy emocionado de dar esta charla en Tech Lead Conf. Gracias por tomarse el tiempo para unirse a nosotros. Así que, hoy, vamos a echar un vistazo juntos a lo que está mal con las pruebas de codificación en línea, por qué leetcode está muerto, y cómo incluir una entrevista de programación en pareja puede revolucionar todo su proceso de entrevista.

Entonces, quiero comenzar dando una visión general de lo que vamos a hablar hoy. En primer lugar, muy rápidamente, ¿por qué importa el crecimiento? ¿Y por qué deberías enfocarte en las entrevistas? Dos, ¿qué estás buscando en el candidato ideal? ¿Cuáles son las características clave, rasgos, habilidades que deberías apuntar? Sabiendo eso, en tercer lugar, ¿cuáles son las habilidades que las plataformas de codificación en línea como leetcode, como HackerRank están realmente testing? ¿Coinciden bien con las habilidades que necesitas buscar en un candidato? Y por último, profundizaremos en todo el enfoque de la programación en pareja.

Entonces, un poco sobre mí y dónde trabajo. Mi nombre es Muhammad. Soy el jefe de móviles en una empresa llamada Theodo, con sede en el Reino Unido. Theodo es en realidad una consultoría global con más de 600 personas distribuidas en el Reino Unido, Francia, Estados Unidos y Marruecos. Ayudamos a los clientes a construir soluciones digitales para algunos desafíos estratégicos difíciles. Cosas como autoservicio y recorridos minoristas, plataformas de e-commerce para ropa de segunda mano, o construir bancos desafiantes desde cero. Entonces, si estás interesado en aprender un poco más sobre Theodo o simplemente quieres charlar, no dudes en enviarme un mensaje en Twitter. Siempre estoy dispuesto a tomar un café en persona o tener una charla virtual.

A nivel personal, la razón por la que realmente quería dar esta charla fue debido a mi propio viaje al unirme a Theodo. Mi decisión de unirme a la empresa fue en gran medida influenciada por mi propia entrevista de programación en pareja. Fue una experiencia realmente agradable que me empujó a decir que sí y unirme a Theodo y al equipo que tenemos. Entonces, el impacto de esto se siente mucho en mi propia career. Y ahora soy una de las personas que realiza las entrevistas de programación en pareja. Así que, hemos llegado a un punto completo. Y es algo que realmente disfruto. Así que estoy muy emocionado de compartirlo con todos ustedes hoy. Vamos a empezar.

¿Cuál es la importancia de la contratación y el crecimiento? No voy a dedicar mucho tiempo a esto, pero realmente, si lo analizas, puedes dividirlo en tres categorías. Uno es la calidad del equipo. Esto puede parecer muy, muy simple. Pero una alta calidad de contratación conducirá a equipos de mayor calidad. Entonces, sin tener un proceso de entrevista bien pensado y de buena calidad, corres el riesgo de tener falsos positivos. Así que, tal vez contratar a los candidatos equivocados, alguien que no encaja en el equipo o que no tiene las habilidades que estabas requiriendo.

2. Importance of Hiring and Growth

Short description:

Tener un sistema de contratación efectivo es crucial para contratar a los candidatos adecuados y evitar falsos negativos. El proceso de contratación puede afectar la reputación de una empresa, por lo que es importante crear una experiencia agradable y positiva para los solicitantes. Además, se debe tener en cuenta el costo de contratación, incluido el pago para los candidatos y el tiempo invertido por los entrevistadores. Al buscar candidatos, es importante centrarse en su capacidad para escribir código mantenible y comprensible, ya que el código se lee con más frecuencia de lo que se escribe.

O tendrás falsos negativos. Y eso no significa contratar a los candidatos adecuados. A veces, tener un sistema que no es efectivo te hará perder algunos candidatos realmente buenos que podrían haber sido un activo muy valioso para tu equipo y tu empresa.

En segundo lugar, la reputación de la empresa. Recuerdo cuando era recién graduado y buscaba trabajo, una de las cosas que se mencionaba regularmente entre mis compañeros era que ciertas empresas eran difíciles de solicitar. ¿Por qué perder el tiempo? Tenían cierta reputación de ser un poco difíciles y de no ser procesos agradables para pasar. Y por eso era conocido entre la comunidad estudiantil, probablemente no quieras perder tu tiempo solicitando en ellas o es realmente difícil. El proceso de contratación puede tener impactos realmente positivos y realmente negativos en la reputación de la empresa. Y a lo largo de todo ese proceso de entrevista y contratación, puedes aprovecharlo como una oportunidad para conocer a más ingenieros, aprender sobre las experiencias de las personas, compartir tus propias experiencias. Y es una oportunidad realmente buena para conocer a más personas en toda esa entrevista y etapa de contratación. Así que es bueno para la reputación y también una buena oportunidad para que conozcas a más personas.

Y por último, el costo. Entonces, si estás empezando a considerar ser un EM o un líder técnico, una de las cosas importantes con las que tendrás que lidiar es el costo. Eso incluye desde el costo del pago para el candidato. A corto plazo, está el costo de un equipo sordo que va a entrevistar al candidato. El costo de su tiempo que están invirtiendo para pasar por estas entrevistas con tu candidato, ver si son adecuados o no. Y luego, en el peor de los casos, si el candidato no era adecuado y necesitabas volver a contratar en algún momento, el costo de tener que volver a contratar obviamente también puede ser bastante alto. Así que con todo eso en mente, podemos tener una visión general de por qué es importante la contratación y el crecimiento y por qué debemos centrarnos en esto. ¿Qué debemos buscar en un candidato? Tengo algunos rayos de sol y la figura solitaria para darle este tipo de ambiente grandioso y sagrado. Así que este es un candidato perfecto. Estoy seguro de que en algún momento todos hemos oído hablar de este concepto del desarrollador 10X. Es el desarrollador que puede entregar a 10 veces la velocidad con una décima parte de las líneas de código. Me alegra decir que después de una extensa investigación, he llegado a la conclusión de que el desarrollador 10X es una mentira. Es una fachada total. No existe. Y a lo largo de mi investigación sobre el desarrollador 10X, en realidad encontré esta cita realmente genial que me gustó, que decía que el código se lee cuatro veces más de lo que se escribe. Entonces, si escribes código fácil de razonar, eso se paga dramáticamente en el futuro. Creo que realmente engloba algunos factores clave sobre lo que es importante cuando buscas contratar a un candidato. Quieres a alguien que pueda escribir buen código, código que será mantenible y comprensible por otros, por miembros más senior del equipo, miembros más junior del equipo, y código que en última instancia sea comprensible y razonable por otros en ese equipo. Y eso es lo que hará que esa inversión de 10X valga la pena a largo plazo, porque ese código será revisado y examinado tantas veces en el futuro y en el ciclo de vida de una base de código.

QnA

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Impacto: Creciendo como Ingeniero
React Summit 2022React Summit 2022
27 min
Impacto: Creciendo como Ingeniero
Top Content
This Talk explores the concepts of impact and growth in software engineering. It emphasizes the importance of finding ways to make the impossible possible and the role of mastery in expanding one's sphere of impact. The Talk also highlights the significance of understanding business problems and fostering a culture of collaboration and innovation. Effective communication, accountability, and decision-making are essential skills for engineers, and setting goals and finding sponsors can help drive career growth. Feedback, goal setting, and stepping outside of comfort zones are crucial for personal development and growth. Taking responsibility for one's own growth and finding opportunities for impact are key themes discussed in the Talk.
Sobre convertirse en un Tech Lead
TechLead Conference 2023TechLead Conference 2023
25 min
Sobre convertirse en un Tech Lead
Top Content
The role of a Tech Lead involves shaping the roadmap, helping the team be more effective, and working on important projects. Lessons learned include encouraging idea sharing, avoiding taking on all the work, and focusing on delegation. Tech Leads focus on the outcome, involve the team in decision-making, and make plans based on how different pieces will interact. The role of a Tech Lead is to focus on engineering and guide the team in figuring out how the whole system should fit together. Architecting can become problematic when it loses touch with the coding part, resulting in implementation issues.
Comunicación Efectiva para Ingenieros
TechLead Conference 2023TechLead Conference 2023
36 min
Comunicación Efectiva para Ingenieros
Top Content
Today's Talk covers the four building blocks of communication: people, message, context, and effective listening. It emphasizes the importance of considering the perspective of others and tailoring messages to the recipient. The Talk discusses different types and channels of communication, and the need to align them with the intended message. It also highlights the significance of soft skills in communication and provides techniques for effective communication and assessing soft skills in tech interviews. Cross-cultural communication and the impact of bluntness are explored as well.
Una Carrera Como Ingeniero de Software
React Advanced 2022React Advanced 2022
24 min
Una Carrera Como Ingeniero de Software
Code will be imperfect and perishable, so testing and debugging are crucial. Building relationships and being generous with code reviews are important for teams. Code ownership should belong to the team, not individuals. Prioritizing functionality over consistency can lead to more efficient development. Growing into a tech lead role requires building relationships and coaching skills.

Workshops on related topic

De Ingeniero a Líder: Un Masterclass para Líderes Tecnológicos Primerizos
TechLead Conference 2024TechLead Conference 2024
144 min
De Ingeniero a Líder: Un Masterclass para Líderes Tecnológicos Primerizos
Workshop
Andrew Murphy
Andrew Murphy
Transicionar de un rol de contribuidor individual a una posición de liderazgo, especialmente en la industria tecnológica de ritmo acelerado, es enormemente desafiante. La mayoría de los nuevos líderes no reciben ningún tipo de capacitación en los primeros 10 años de sus nuevas responsabilidades.Nuestro completo masterclass está diseñado para ayudar a los nuevos y emergentes líderes tecnológicos a comprender sus nuevos roles y adquirir las habilidades para convertirse en líderes seguros, felices y efectivos.
Managers Are From Mars, Devs Are From Venus
TechLead Conference 2024TechLead Conference 2024
111 min
Managers Are From Mars, Devs Are From Venus
Workshop
Mo Khazali
Mo Khazali
Una Guía para Desarrolladores sobre Cómo Comunicar, Convencer y Colaborar Efectivamente con los Stakeholders
Es una historia tan antigua como el tiempo: la colaboración entre desarrolladores y stakeholders de negocios ha sido durante mucho tiempo un desafío, con una falta de comunicación clara que a menudo deja a ambas partes frustradas. Los mejores desarrolladores pueden comprender profundamente las necesidades de sus contrapartes de negocios, comunicar efectivamente la estrategia técnica sin perder a la audiencia no técnica y convencer al negocio de tomar las decisiones correctas. Trabajando en una consultoría, he fallado y tenido éxito en arquitectar y “vender” visiones técnicas, aprendiendo muchas lecciones en el camino.Ya sea que trabajes en una empresa de productos, seas consultor/freelancer, o quieras aventurarte más allá de ser solo un desarrollador, la capacidad de convencer y comunicar claramente con los stakeholders puede diferenciarte en la industria tecnológica. Esto se vuelve aún más importante con el auge de GenAI y el mercado de desarrolladores cada vez más competitivo, ya que la resolución de problemas y la comunicación efectiva son clave para posicionarte.En esta masterclass, compartiré ejemplos del mundo real, tanto buenos como malos, y te guiaré a través de poner la teoría en práctica mediante dojos.
Cómo Diseñar una Carrera de Freelance/Contratación Sostenible + Desafío de Codificación Rápida
React Summit 2022React Summit 2022
75 min
Cómo Diseñar una Carrera de Freelance/Contratación Sostenible + Desafío de Codificación Rápida
WorkshopFree
Shane Ketterman
Shane Ketterman
¿Listo para comenzar tu carrera como freelance o recién estás comenzando en tu viaje freelance? Estás en el lugar correcto. Aprende de la fuerza laboral totalmente distribuida más grande del mundo.
El movimiento de talento independiente es el futuro del trabajo. Si estás considerando dejar el empleo a tiempo completo para una carrera como freelancer, ahora es el momento de encontrar tu espacio exitoso en la fuerza laboral de talento independiente. Más personas están trabajando como freelance hoy que nunca antes, y el mercado freelance ahora contribuye con $1.2 billones a la economía de los Estados Unidos. Algunos de los roles más demandados para freelancers en este momento son desarrolladores senior con experiencia profesional en React, Python, Blockchain, QA y Node.js.
Este masterclass te ayudará a diseñar una carrera de freelance/contratación sostenible y rentable a tiempo completo (o parcial). Te proporcionaremos herramientas, consejos, mejores prácticas y te ayudaremos a evitar errores comunes.
Al final del masterclass habrá una sesión de preguntas y respuestas con un Desarrollador Freelance que puede responder tus preguntas y brindar información y consejos sobre su propio éxito.
¡Durante el descanso del masterclass, realizaremos un desafío de codificación rápida! Al final del masterclass, otorgaremos un premio al ganador y mostraremos la tabla de clasificación.
Te haremos iniciar sesión en nuestro portal y completar el desafío lo más rápido posible para ganar puntos. Los puntos se asignan en función de la dificultad y la velocidad con la que resuelvas las tareas. En caso de que completes todas las tareas, obtendrás puntos extra por el tiempo restante. Verás tu puntaje, clasificación y la tabla de clasificación una vez que completes el desafío.
Estaremos regalando tres Tarjetas de Regalo de Amazon ($200, $100, $75) para los tres primeros ganadores.
Diseñando una Carrera de Freelance Sostenible
React Advanced 2021React Advanced 2021
145 min
Diseñando una Carrera de Freelance Sostenible
WorkshopFree
Alexander Weekes
Rodrigo Donini
2 authors
¿Te gustaría perseguir tus pasiones y tener más control sobre tu carrera? ¿Te gustaría tener flexibilidad de horario y ubicación y variedad de proyectos? ¿Te gustaría tener la estabilidad de trabajar a tiempo completo y recibir un pago constante? Miles de empresas han adoptado el trabajo remoto y se dan cuenta de que tienen acceso a un grupo de talentos global. Esto es ventajoso para cualquier persona que haya considerado o esté considerando trabajar como freelance.>> Envía tu interés en convertirte en un ingeniero freelance con Toptal y recibir una llamada de un especialista en adquisición de talento <<

El trabajo freelance ya no es una elección de carrera inestable.

Este masterclass te ayudará a diseñar una carrera de freelance a tiempo completo (o parcial) sostenible y rentable. Te daremos herramientas, consejos, mejores prácticas y te ayudaremos a evitar errores comunes.
Tabla de contenidos

Módulo 1: Desmitificando los mitos comunes sobre el trabajo freelance
Módulo 2: ¿Cómo se ve el trabajo freelance en 2021 y más allá?
Módulo 3: Elecciones freelance y qué buscar (y qué evitar)
Módulo 4: Beneficios del trabajo freelance desde la perspectiva de un freelancer + estudio de caso
DESCANSO
Módulo 6: Cómo comenzar a trabajar como freelance (experiencia, currículum, preparación)
Módulo 7: Caminos comunes hacia el trabajo freelance a tiempo completo
Módulo 8: Aspectos esenciales: establecer tu tarifa y conseguir trabajo
Módulo 9: Próximos pasos: establecer contactos con colegas, mejorar tus habilidades, cambiar el mundo
Módulo 10: Preguntas y respuestas con freelancers
Aterrizando tu Próximo Trabajo de Desarrollador
React Summit Remote Edition 2021React Summit Remote Edition 2021
121 min
Aterrizando tu Próximo Trabajo de Desarrollador
WorkshopFree
Sadek Drobi
Nouha Chhih
Francois Bohyn
3 authors
Renaud Bressant (Jefe de Producto), Nathanael Lamellière (Jefe de Éxito del Cliente e Ingeniero de Soluciones), Nouha Chhih (Gerente de Experiencia del Desarrollador) estarán analizando los diferentes trabajos de desarrollador que puedes encontrar al buscar tu próximo rol de desarrollador. Explicaremos los detalles de cada rol para ayudarte a identificar cuál podría ser tu próximo movimiento. También compartiremos consejos para ayudarte a navegar por el proceso de contratación, basados en los diferentes roles para los que hemos entrevistado como reclutadores, pero también como candidatos. Esta será más bien una sesión de Pregúntanos lo que quieras, así que no dudes en compartir tus pensamientos y preguntas durante la sesión.
Fuera de la sartén, al fuego: Guía para gerentes sobre cómo ayudar a los nuevos desarrolladores a prosperar
TechLead Conference 2024TechLead Conference 2024
35 min
Fuera de la sartén, al fuego: Guía para gerentes sobre cómo ayudar a los nuevos desarrolladores a prosperar
Workshop
Andrew Coleburn
Andrew Coleburn
Integrarse a un nuevo proyecto puede ser difícil, sin importar tu experiencia y antecedentes. Pero puede ser especialmente desafiante para los nuevos desarrolladores recién salidos de la escuela o de un bootcamp de programación. Basándose en su experiencia personal como graduado de un bootcamp y consultor de JavaScript, esta charla discutirá consejos y estrategias para que los gerentes ayuden a los nuevos desarrolladores de sus equipos a familiarizarse con un código desconocido, para que puedan tener un impacto más rápido y efectivo.