Contents

FreeTalk
2015.06.23 13:00

문제는 알고리즘이다

조회 수 370 댓글 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. 홈조이(Homejoy)가 문을 닫은 진짜 이유

    홈조이(Homejoy)가 문을 닫은 진짜 이유 얼마전, 벤처캐피털들로부터 큰 투자를 받고 고속 성장하던 스타트업 하나가 문을 닫는다고 발표했다. 홈조이(Homejoy)라는 집 청소 연결 서비스이다. 홈조이는 그 이유를 청소하는 사람들이 낸 네 건의 소송 때문이라...
    Date2015.08.06 CategoryFreeTalk Byhooni Views605
    Read More
  2. 기업은 언제 망하는 거임?

    옛날 부터 그랬군.. 1842 - 파업이 법적으로 허용된다면 살아남을 기업은 없어! 1887 - 흑인에게 똑같은 임금을 주라고? 기업 망하라는 소리 같은데? 1912 - 노동자의 죽음은 비극이지만 노동착취 반대법은 기업의 종말을 초래할거야!! 1915 - 노조원이란 이유...
    Date2020.03.24 CategoryFreeTalk Byhooni Views605
    Read More
  3. 한국인 관광객 경고문

    호주에서도 한글만 이런 경고문이 써있던거에 챙피했음.. - 빨대를 가져가지 마시오. - 자판기를 치지 마시오. - 쓰레기를 버리지 마시오. 오죽했으면.. 이라는 생각이 든다.
    Date2014.10.16 CategoryFreeTalk Byhooni Views604
    Read More
  4. 안드로이드 폰에서 원격으로 지문 탈취 가능

    우리의 지문은 우리가 생각하는 것 보다 안전하지 않을지도 모른다. 수요일(2015.08.05) 라스베이거스에서 열린 "Black Hat" 컨퍼런스에서 "FireEye"라는 보안업체 직원 "Tao Wei"와 "Yulong Zhang"는 안드로이드 폰에서 사용자 지문을 추출하는 방법을 소개했...
    Date2015.08.07 CategoryFreeTalk Byhooni Views604
    Read More
  5. 'Loading' Christmas Card

    This is a cool and festive "Retro Loading Screen" christmas card. It features 8-bit clip art and a retro computer font. This a perfect Christmas card for any techie. Step 1: Supplies Here is a list of what you will need: Packing tape Black ...
    Date2016.12.05 CategoryFreeTalk Byhooni Views604
    Read More
  6. 핀란드 구제역 발생률 0%의 비밀은?

    "구제역? 우린 몰라요." 핀란드 농업장관이 밝힌 발생률 0%의 비밀 돼지 꼬리는 원래 20~50㎝. 길다. 가만히 두면 돌돌 말린다. 우리나라 돼지는 대부분 꼬리가 사람 손가락만큼 짧다. 태어나자마자 잘랐다. 좁은 우리에 가둬 두면 스트레스 때문에 다른 돼지...
    Date2017.06.18 CategoryFreeTalk Byhooni Views604
    Read More
  7. 평범해 보이지만 그러기 힘든 인생

    결혼하고 토끼 같은 자식 한마리 보고 내 명의로 된 집 사고, 차 사고 가족 중에 아픈 사람 아무도 없이 정년까지 무사히 일하고 퇴직해서 손주들 대학까지 가는거 보고 자다가 사망
    Date2018.03.27 CategoryFreeTalk Byhooni Views603
    Read More
  8. 상대방의 입장에서 바라보기

    그대가 옳다고 상대방이 틀린 건 아니다. 상대방의 입장에서 바라보지 않았을 뿐이다.
    Date2022.06.01 CategoryFreeTalk Byhooni Views603
    Read More
  9. 막 한글 배운 할머니들이 쓴 글 15선

    한글을 갓 배운 할머니들이 손수 글을 써내려갔다. 할머니들이 전한 글에는 어머니에 대한 그리움, 먼저 떠나보낸 남편에 대한 사랑, 자식들을 생각하는 마음, 여자로서의 인생이 녹아있다. 그간 확산되며 네티즌들의 마음을 짠하게 만들었던 할머니들의 이야...
    Date2015.01.01 CategoryFreeTalk Byhooni Views602
    Read More
  10. 외국인의 문화 갈등 모음

    외국인의 문화 갈등 모음
    Date2015.01.24 CategoryFreeTalk Byhooni Views602
    Read More
  11. 애플 “안드로이드 개발자 뽑아요”

    애플이 미국 현지시각으로 8월5일 홈페이지에 새 구인공고를 냈다. 개발자를 뽑겠다는 안내문인데, 채용 부문이 독특하다. 애플은 현재 안드로이드 소프트웨어 엔지니어를 뽑는 중이다. 안드로이드 개발자를 뽑는다는 공고는 흔하지만, 이 공지가 애플로부터 ...
    Date2015.08.07 CategoryFreeTalk Byhooni Views602
    Read More
  12. 어느 아버지의 재산 상속 - 실화

    어느 아버지의 상속 재산 (실화) S시에 거주하는 한 아버지가 4남매를 잘키워 모두 대학을 졸업시키고 시집, 장가를 다 보내고.. 한 시름 놓자 그만 중병에 걸린 사실을 알고 하루는 자식과 며느리, 딸과 사위를 모두 불러 모았다. 내가 너희들을 키우고, 대...
    Date2016.10.19 CategoryFreeTalk Byhooni Views602
    Read More
Board Pagination Prev 1 ... 44 45 46 47 48 49 50 51 52 53 ... 73 Next
/ 73