Contents

FreeTalk
2015.06.23 13:00

문제는 알고리즘이다

조회 수 368 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

수만 명의 회원이 가입한 생활코딩이라는 페이스북 그룹이 있다. 나도 최근에 회원으로 가입했는데, 여러 가지 포스팅 중에서 간혹 알고리즘에 대한 질문이 올라오는 것을 보게 된다. “프로그래밍을 하려면 알고리즘을 꼭 알아야 하나요?” “개발자에게 알고리즘은 얼마나 중요한가요?” 이와 같은 내용의 질문이다.

알고리즘이라고 하면 병합정렬, 그래프검색, 동적프로그래밍 등과 같이 구체적인 ‘알고리즘’을 떠올리는 경우가 일반적이다. 아마 질문을 올린 사람도 그런 알고리즘을 염두가 두었을 것이다. 그렇기 때문에 위의 질문을 “PHP로 웹사이트를 개발하고 있는데 반드시 병합정렬을 알아야 하나요?”처럼 좁은 의미로 해석하면 대답하기가 쉽다. 웹사이트를 개발하기 위해서 꼭 병합정렬을 알아야 할 필요는 없기 때문이다.

그렇지만 우리가 이야기하는 알고리즘이라는 것이 그렇게 특정한 ‘알고리즘’을 모아놓은 것을 의미할까. 이 부분이 핵심이다. 제대로 된 답을 구하려면 우선 질문을 제대로 구성하는 것이 중요하다. 메리엄-웹스터 사전에 나와 있는 알고리즘의 정의를 살펴보자.

“a set of steps that are followed in order to solve a mathematical problem or to complete a computer process”

수학적인 문제를 해결하거나 컴퓨터 프로세스를 완결하기 위해서 차례로 뒤따르는 단계의 집합. 이게 알고리즘이다. 여기에서 “단계의 집합”은 “규칙의 집합”이라고 바꿔 불러도 좋을 것이다. 이러한 정의에 따르면 알고리즘은 어떤 문제를 해결하기 위해서 필요한 규칙을 이해하고 그러한 규칙을 단계별로 적용해서 문제를 해결하는 것을 의미한다.

다시 질문으로 되돌아가보자. “프로그래밍을 하려면 규칙을 이해하고 그런 규칙을 단계별로 적용하는 능력이 반드시 필요한가요?” 혹은 “개발자에게 규칙을 이해하고 그런 규칙을 적용해서 문제를 해결하는 능력은 얼마나 중요한가요?” 질문을 이렇게 바꾸면 질문 자체가 성립하지 않는다는 사실을 알게 된다. 왜냐하면 “규칙을 이해하고 그런 규칙을 적용해서 문제를 해결하는 것”이 바로 프로그래밍이기 때문이다.

올초 지디넷코리아에 실렸던'컴공 전공자가 왜 SW 개발을 못하나'라는 기사가 개발자 사이에서 잠시 회자되었다. 컴퓨터 공학을 전공한 졸업생들이 회사에 취업했을 때 회사가 원하는 수준의 코딩 실력을 갖추지 못하는 현실을 지적한 내용이었다. 컴공을 전공한 학생이 대학을 졸업하서 코딩을 하지 못하면 확실히 문제다. 하지만 ‘코딩’이 특정 회사가 요구하는 특정 플랫폼, 특정 언어, 특정 API에 대한 내용이면 이야기가 달라진다.

대학은 학원이 아니기 때문이다. 대학에서 학생들이 배워야 하는 것은 특정한 API를 다루는 ‘코딩’ 능력이 아니라 주어진 문제를 해결하기 위해서 규칙을 이해하고 규칙을 단계별로 적용해서 문제를 해결하는 능력이다. 즉, 코딩이 아니라 알고리즘이다. 코딩은 알고리즘이라는 능력이 겉으로 드러나는 여러 가지 방식의 하나일 뿐이다. 코딩은 외공이고 알고리즘은 내공이다.

그렇기 때문에 대학은 학생들에게 코딩 능력이 아니라, 문제를 해결할 수 있는 능력, 즉 알고리즘 능력을 길러주는 방법을 고민해야 한다. 살에 새긴 문신 같은 코딩 능력은 MOOC, 학원, 스터디 그룹 등을 통해서 필요할 때 얼마든지 배울 수 있다. 지울 수도 있다. 하지만 뼈에 녹아들어 나와 한 몸이 되는 알고리즘 능력은 그 자체로 프로그래머의 정체성을 규정한다. 그렇기 때문에 배워야 하는 시기가 따로 있다. 시기를 놓치면 익히기 어렵다.

요즘처럼 기술변화의 속도가 빠른 시대에는 특정 기술, 플랫폼, 언어, API에 종속되는 코딩 기술의 가치가 전보다 크지 않다. 오히려 낡은 기술을 버리고 새로운 기술을 재빨리 익히는 능력이 중요하다. 전투기의 생명이 빠르게 방향을 전환하는 기동성(maneuverability)에 달려 있는 것처럼, 프로그래머의 생명도 방향전환 능력에 달려있다. 알고리즘은 그러한 방향전환을 가능하게 만들어주는 일종의 “메타-능력”이다.

그래서 미국의 IT 회사들은 (특별한 경우를 제외하면) 특정 기술이나 API에 정통한 사람을 찾지 않는다. 기본적인 능력(문제를 해결할 수 있는 능력, 즉 알고리즘)을 갖춘 상태에서 새로운 기술을 빠르게 습득해서 활용할 수 있는 사람을 찾는다. 이런 면들을 생각해보면 실리콘밸리라는 미국드라마에서 해커 느낌이 풍기는 보안전문가와 자바전문가가 아니라 파일을 압축하는 ‘알고리즘’을 개발한 사람을 주인공으로 배치한 것은 우연이 아니었을 것이다.

프로그래밍이라는 기술은 이렇게 알고리즘이라는 세포로 이루어져 있다. 그리고 알고리즘이라는 세포의 내부에 존재하는 DNA는 논리다. 만사에 논리적인 사람은 좋은 코드를 작성하지만, 논리적 사고가 결핍되어 있는 사람은 아무리 열심히 ‘코딩’을 배워도 좋은 코드를 작성하지 못한다. 다시 질문으로 되돌아가보자.

“프로그래밍을 하려면 알고리즘을 꼭 알아야 하나요?” “개발자에게 알고리즘은 얼마나 중요한가요?”

이제 질문의 의미를 정확하게 이해할 수 있게 되었으므로 대답을 할 수 있다. 그렇다. 프로그래밍을 하려면 알고리즘이라는 메타 능력이 반드시 있어야 한다. 알고리즘이 얼마나 중요한가하면 프로그래밍 그 자체라고 말할 수 있을 정도로 중요하다. 문제는 알고리즘이다.


[출처] http://www.zdnet.co.kr/column/column_view.asp?artice_id=20150622080223

?

  1. 기술 경시 풍조가 낳은 위기

    "목에 칼이 들어왔다." 기술 경시 풍조가 낳은 위기
    Date2016.02.15 CategoryFreeTalk Byhooni Views317
    Read More
  2. 한국 일정과 할 일 (초안)

    # LAX 장기주차 정보 QuikPark LAX 9821 Vicksburg Ave. Los Angeles, CA 90045 (310) 645­7754 https://www.google.com/maps/place/9821+Vicksburg+Ave,+Los+Angeles,+CA+90045/@33.9467665,-118.3967788,17z/data=!3m1!4b1!4m5!3m4!1s0x80c2b12af550b501:0x...
    Date2023.06.12 CategoryFreeTalk Byhooni Views317
    Read More
  3. 6조 8,900억원의 자산가는 국민연금으로 얼마를 내고 있을까요?

    월급이 200만원인 김OO씨는 18만원을 냅니다. 월급이 300만원인 박OO씨는 27만원을 냅니다. 그런데 월급이 20억원이 넘는 이OO 부회장은 37만원도 채 안되는 돈을 냅니다. [출처] www.facebook.com/mediatodaynews 만약 소득 상한이 없다면 월 20억원을 버는 ...
    Date2016.02.15 CategoryFreeTalk Byhooni Views321
    Read More
  4. [펌] 죄송합니다.. 차라리 징역 가겠습니다..

    감동의 도가니.. 어머니, 아버지, 형까지 차례로 여의고 희망 없는 노숙생활을 하면서 문 열린 차량에서 동전을 절취해서 하루하루 살아감.. 구속과 출소, 노숙생활의 반복이 뻔한 상황에서 피해자들은 처벌의사도 없고 해서 담당형사가 이 남자를 돕기로 함. ...
    Date2016.01.13 CategoryFreeTalk Byhooni Views322
    Read More
  5. 보고서 작성 원칙 : 프로의 보고서에는 'will'이 다르다

    형님~ 잘 지내시죠? 저는 회사 생활 적응하느라 죽겠습니다. 신참이라 해야 할 일도 많은데 뭘 해도 칭찬을 듣는 날보다 야단맞는 날이 더 많은 듯 합니다. 도대체 보고서는 어떻게 쓰면 잘 쓸 수 있는건가요? 시중에 나와 있는 기획서나 보고서 관련 책들을 ...
    Date2015.11.12 CategoryFreeTalk Byhooni Views322
    Read More
  6. 다른 각도에서 찍은 사진들

    나도 저렇게 찍어봐야지.. ㅋㅋ
    Date2016.05.28 CategoryFreeTalk Byhooni Views322
    Read More
  7. 한 장의 사진을 얻기 위해 #1

    막연히 CG 합성이라 생각했는데.. 착시와 원근을 이용해서 찍을 수도 있구나~ ㅋㄷ 대박 사진 촬영
    Date2016.07.11 CategoryFreeTalk Byhooni Views324
    Read More
  8. ‘언젠가’라는 병

    완성된 후 뭔가 할려고 하면 이미 시간이 지나버린.. 스타크래프트 할 때 생각나네~ 만렙 채우고 쳐들어 갈려면 이미 늦음 ㅋㅋ 삶의 신호등들은 동시에 초록색으로 바뀌지 않는다. '언젠가'라는 말은 당신의 꿈을 무덤까지 데려가는 병인 것이다. [출처] http...
    Date2015.06.03 CategoryFreeTalk Byhooni Views329
    Read More
  9. No Image

    어떻게 해야 할까?

    어떻게 할까? 어느 의과대학에서 교수가 학생들에게 질문했다. "한 부부가 있습니다. 남편은 매독에 걸려 있고, 아내는 중증 폐결핵에 걸려 있습니다. 이미 가정에는 아이들이 넷이나 있었죠. 한 명은 얼마 전 병으로 죽었고, 남은 아이들도 결핵으로 누워있어...
    Date2015.08.22 CategoryFreeTalk Byhooni Views330
    Read More
  10. 대부분 호텔에 420호가 없는 이유

    호텔에 가게 된다면 방 번호를 유심히 살펴보자. 아마도 420호가 없는 호텔들이 꽤 많다는 것을 발견할 수 있을 것이다. 420호가 없는 호텔들은 보통 319호 다음에 바로 421호로 넘어가거나 420호를 직접 표기하지 않고 419+1호로 표시한다고 한다. 이렇게 하...
    Date2023.09.08 CategoryFreeTalk Byhooni Views330
    Read More
  11. 인공지능.. 진짜 이런 날이 가까웠는지도..

    이러다 인공지능이 사람의 지능을 뛰어 넘는거 아닌가? 그러면 전문가들은 이렇게 말한다. - 사람의 지능을 능가하려면 아직 멀었다고.. - 특정 분야에 국한된 지능이라고.. 하지만 로봇은 이렇게 생각하지 않을까?
    Date2016.03.10 CategoryFreeTalk Byhooni Views332
    Read More
  12. 이렇게 멀어진다. 어떤 사람들과 난..

    내가 알던 어떤 사람.. 나를 위해주는 말과 행동에 나는 고마움을 느낀다. 하지만, 시간이 지나면서 우연히 알아버렸다. 그 사람도 어차피 그래야 하는 상황이었다. 심지어 결국 나를 위한 말과 행동이 아니었다. 그런데 고맙다고 했으니 그 동안 나는 얼마나...
    Date2016.09.01 CategoryFreeTalk Byhooni Views334
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 73 Next
/ 73