7 tuyệt kỹ giúp lập trình viên đậu phỏng vấn

Làm thế nào để bạn có thể viết code thật hay khi làm bài test vào vị trí lập trình viên của các công lớn?

Theo các chuyên gia phỏng vấn tại Gainlo, phần lớn các ứng viên khi được yêu cầu viết code thử thì chất lượng khá là thấp, bao gồm bug, cách viết dở, phức tạp, không nhất quán,… Một điều đáng quan tâm hơn là nếu bạn có khả năng code gọn và “sạch” thì rất dễ được nhận vào làm bởi vì ứng dụng của bạn sẽ ít bị bug, lỗi mà lại dễ sửa.

Trong bài viết này, chúng tôi sẽ đưa ra những tip và trick thực tiễn nhằm giúp bạn cải thiện chất lượng code nhanh nhất có thể. Thậm chí, một số cách chỉ tốn của bạn 30 phút thôi nhưng chúng đều rất hữu ích và không đòi hỏi bạn phải có kiến thức thâm sâu mới làm được.

Chọn ngôn ngữ lập trình

Đa phần các công ty đều cho phép ứng viên được tự do chọn bất cứ ngôn ngữ nào mà họ thích và thường gặp nhất chính là C++Java. Mặc dù chúng không có sự cách biệt mấy bởi cả hai đều quá nổi tiếng, tuy nhiên từ dữ liệu thu thập được, C++ lại có những thế mạnh nổi trội hơn hẳn so với Java.

Đầu tiên, C++ có cú pháp ngắn gọn hơn. Các bạn nên biết rằng, thông thường, công ty sẽ chỉ cho khoảng 20 phút để giải một vấn đề code và nếu lược ra khoảng thời gian ta suy nghĩ, thì chỉ còn xấp xỉ 10 phút để code thôi. Như vậy, C++ sẽ cho phép bạn giải quyết vấn đề nhanh hơn và gọn hơn. Hãy thử so sánh list/vector và class, bạn sẽ thấy ngay Java rườm rà thế nào.

C++ pointer là một tool cực kì tuyệt vời cho việc làm test khi đi phỏng vấn.

Như nhiều người khác, tôi cực kì ghét pointer bởi dễ bị lỗi và nhìn xấu. Tuy nhiên, nó lại khá hữu ích trong trường hợp test coding trong phỏng vấn. Ví dụ, pointer sẽ ngay lập tức cho phép bạn xác định một phương pháp để có thể chạy nhiều giá trị cùng một lúc với pointer đóng vai trò như param.

Ngoài ra, Python cũng là một lựa chọn khá tốt mặc dù không phải ai cũng rành về nó. Tuy vậy, cú pháp rõ ràng đơn giản khiến Python trở thành một ngôn ngữ cực kì mạnh mẽ đối với các bài test về coding trong phỏng vấn. Thế nên nếu bạn giỏi Python thì hãy dùng nó ngay.

Screen Shot 2015-09-24 at 8.50.20 AM

Phong cách viết code chuẩn

Mặc dù cách viết code mỗi nơi mỗi khác, nhưng bạn vẫn phải chú ý tới bởi code xấu thể hiện sự thiếu chuyên nghiệp của bạn. Bạn có thể học theo phong cách của Google trong Java, C++ Python vốn rất nổi tiếng.

Hơn nữa, ta cũng cần chú ý đến việc đặt tên cho các variable. Mặc dù việc gọi chúng là X,Y hoặc Z thực sự không nên nhưng trong trường hợp này thì nó lại giúp bạn tiết kiệm rất nhiều thời gian. Đừng đặt những cái tên dài ngoằng bởi điều quan trọng nhất là phải khiến nó dễ đọc, dễ hiểu cũng như tiện gỡ bug cho bạn và cả người phỏng vấn.

Giữ cho code luôn sạch và hoàn chỉnh

Khi tôi nói hoàn tất tức là code của bạn phải có đầy đủ mọi yếu tố để có thể complie và chạy được. Nếu vấn đề đặt ra cho bạn là cách áp dụng một function, thì hãy bắt đầu với bước declaration thay vì cắm đầu viết trực tiếp. Còn nếu là xác định class thì đầu tiên sẽ phải là phân tích class.

Ngoài ra, bạn cũng cần phải khai báo ra tất cả variable. Thật ngạc nhiên thực tế lại ngược lại khi có khá nhiều ứng viên cứ sử dụng variable mà không cho biết nó ở đâu ra cả.

Về vấn đề code gọn và sạch, ý của tôi ở đây ám chỉ vẻ ngoài của nó. Khi bạn viết code trên bảng trắng, thì việc viết cho đẹp, cho sạch luôn được ủng hộ. Bởi có một số kí tự dễ bị nhầm lẫn như “q” với 9 và “z” với 2, vì thế hãy luôn viết thật rõ ràng.

Cũng nên bỏ việc dùng mũi tên để thêm code vào theo ý bạn, nhìn rất xấu. Bạn có thể cho thêm space giữa các dòng phòng khi muốn thêm thắt hoặc là phải viết cẩn thận và chậm.

Ngắn gọn

Hãy giữ cho code của bạn thật ngắn gọn hết mức. Có rất nhiều lợi ích cho việc đó. Đầu tiên, việc bug xuất hiện ít hơn bởi tỉ lệ bug/dòng luôn thấp. Mặc khác, người phỏng vấn sẽ rất ấn tượng khi bạn đưa ra được câu trả lời chính xác mà ngắn gọn. Hơn nữa, viết ngắn thì sẽ tiết kiệm được thời gian.

Tất nhiên để làm được việc này thì ta cần phải rèn luyện rất nhiều và lời khuyên của tôi là khi bạn viết code, hãy luôn lọc và cải thiện giải pháp của mình để khiến nó ngắn hơn cũng như nhận ra một số kiểu vấn đề mà bạn có thể dùng cách riêng của mình. Hẳn bạn đã chán việc phải viết những đoạn code dài ngoằn mà vô nghĩa.

Thay vào đó bạn có thể nhờ tới một số Hack sau:

  • Dùng C++ auto trong loop. Thay vì phải viết
for(int i = 0; i < array.size(); ++i)

Bạn có thể dùng auto như sau

for(const auto& element : array)
  • Cố gắng đặt “if” và “for” trong cùng một dòng
for(const auto& ele : array) if (ele.attr) res[++i] = ele.val;

Luôn phải xác nhận Input trước

Một điều rất đơn giản nhưng các ưng viên lại hay bỏ qua. Hãy luôn kiểm tra xem input có NULL, empty, positive, etc. Và đừng bao giờ tự nhủ rằng bạn được cho một valid param.

Hơn nữa, khi bạn muốn test phương pháp của mình, hãy dùng một số input “quái quái” tí để coi kết quả như thế nào. Hãy bảo đảm phương pháp của bạn đủ mạnh mẽ để xử lí hết tất cả mọi trường hợp được đặt ra.

Tránh mất thời gian vào việc define các function không quan trọng

Một điều thường gặp ở các ứng viên là họ hay đặt quá nhiều thời gian vào việc define các function một cách không cần thiết. Tuy nhiên, nó sẽ chỉ khiến mọi thứ càng trở nên rắc rối và tốn thời gian hơn.

Đa phần các câu hỏi sẽ không đòi hỏi ta phải define quá 2 function và chỉ những function phụ không cần thiết thường nằm trong 3 trường hợp sau:

  • Utility function hay swap function
  • Được dùng nhiều lần, thế thì bạn nên chỉ viết một lần thôi
  • Nó nằm ở một phần khác so với function chính

Vừa nói vừa viết

Rất nhiều ứng viên im lặng khi đang coding, đó là điều không nên mặc dù đúng là bình thường ta không nói chuyện khi code. Ý tưởng ở đây là tranh thủ thời gian viết code để trò truyện với người phỏng vấn vốn rất có lợi cho bạn.

Trước tiên, nó giúp cho họ hiểu rõ hơn về code của bạn. Khá nhiều người cho rằng code của họ dễ đọc, tuy nhiên sự thật đôi khi nó chỉ dễ đối với họ thôi. Vì thế khi bạn trao đổi với người phỏng vấn, họ sẽ hiểu rõ cũng như có thiện cảm với bạn.

Mặc khác, người phỏng vấn sẽ đưa ra hint và gợi ý giúp bạn. Nghe có vẻ khó tin đúng không nhưng thật sự là phần lớn người phỏng vấn luôn muốn bạn thành công. Vì thế mà thỉnh thoảng họ sẽ đưa ra tip khi bạn bị bí. Do vậy mà nếu bạn chịu khó giao tiếp thì họ sẽ hiểu được tiến độ cũng như khả năng của bạn. Tuy nhiên, một lập trình viên im lặng sẽ không thể nào có cơ hội cải thiện sửa chữa sau 20 phút cặm cụi làm.

Việc vừa giao tiếp vừa code còn giúp bạn biết được mình đang làm gì. Bởi đôi khi chúng ta vì bị tinh thần chưa vững nên khi bị mắc kẹt dễ gây mất bình tĩnh. Thế nên nói chuyện giao tiếp sẽ giúp bản thân chính bạn hiểu thêm về vấn đề cũng nhưng phương hướng của mình.

Lời kết

Hãy luôn nhớ rằng người phỏng vấn sẽ copy code của bạn và gửi lên cho sếp xem. Vì thế mà cách bạn viết code rất quan trọng, mang tính quyết định cho kết quả của buổi phỏng vấn.

Topdev via blog.gainlo.co

Tham khảo việc làm GIT lương cao tại TopDev