목록분류 전체보기 (494)
규도자 개발 블로그
개발자가 알고리즘을 알아야 되는 이유에 대해서 생각해봤다. 일단 나는 정규적인 프로그래밍 학습과정을 거친 것이 아니라 단순 "만들어 보고 싶은 게 있다"는 생각으로 국비학원에서 프로그래밍을 배워 프로그래머로 정착하게 됐다. 국비학원의 특성상 짧은 시간 안에 업에 뛰어들 수 있는 인재를 만들어야 하므로 학과적인 가르침보다는 실무적인 가르침이 컸다. 그마저도 부족한 게 실상이지만. 학원에서 배웠던 알고리즘 비슷한 건 별찍기나 주사위 기록하기, 로또번호 생성기 등 기본 중 기본이었다. 오히려 부족한 학력을 채우기 위해 혼자 따로 공부했던 정보처리기사를 준비하며 배웠던 알고리즘이 훨씬 많았다. 하지만 그때까지만 해도 알고리즘을 왜 배워야 하는지에 대한 정확한 이유에 대해선 몰랐다. 그냥 내가 따려는 자격증에 필..
해당 에러는 django에서 쓰는 패키지인 allauth나 django-rest-auth등 인증 관련 패키지에서 자주 볼 수 있다. 해결법은 간단하다. Site와 일치하는 Query가 없다는 에러이니 Site와 일치하는 Query를 추가해주면 된다. django project root(manage.py가 있는 곳)에서 아래 명령어를 실행하여 django shell로 들어가자. $ python manage.py shell 그리고 아래 명령어를 통해 from django.contrib.sites.models import Site new_site = Site.objects.create(domain='ip혹은 도메인', name='프로젝트 이름') django_site테이블에 정보를 등록해주면 된다.
gunicorn은 대체 뭐하는 놈일까 (부제: CGI, WSGI는 대체 뭐냐) django를 배포하려고 하면 꼭 gunicorn이나 uWSGI라는 놈과 마주친다. 튜토리얼 보스마냥 이 둘을 마주치지 않고 배포를 할 수는 없는 모냥이다. 왜 php는 Apache나 nginx처럼 웹서버만 있으면 되는데 django는 WSGI라 불리는 아이들을 거쳐야 하는 걸까? 한번 알아보자. gunicorn은 WSGI의 일종이다. 그렇다면 WSGI는 뭘까? CGI의 일종이다. 그렇다면 CGI는 뭘까? 그렇다. gucniron이 뭐하는 놈인지 이해하기 위해선 CGI라는 것부터 이해해야 한다. CGI를 풀어써보면 Common Gateway Interface라고 하는데 한국말로 직역하자면 "공용 경로 인터페이스"라고도 할 수 ..
[프로그래머스/Level2/파이썬3(python3)] 기능개발 문제 프로그래머스 팀에서는 기능 개선 작업을 수행 중입니다. 각 기능은 진도가 100%일 때 서비스에 반영할 수 있습니다. 또, 각 기능의 개발속도는 모두 다르기 때문에 뒤에 있는 기능이 앞에 있는 기능보다 먼저 개발될 수 있고, 이때 뒤에 있는 기능은 앞에 있는 기능이 배포될 때 함께 배포됩니다. 먼저 배포되어야 하는 순서대로 작업의 진도가 적힌 정수 배열 progresses와 각 작업의 개발 속도가 적힌 정수 배열 speeds가 주어질 때 각 배포마다 몇 개의 기능이 배포되는지를 return 하도록 solution 함수를 완성하세요. 제한사항 작업의 개수(progresses, speeds배열의 길이)는 100개 이하입니다. 작업 진도는 1..
[프로그래머스/Level2/파이썬3(python3)] 스킬트리 문제 선행 스킬이란 어떤 스킬을 배우기 전에 먼저 배워야 하는 스킬을 뜻합니다. 예를 들어 선행 스킬 순서가 스파크 → 라이트닝 볼트 → 썬더일때, 썬더를 배우려면 먼저 라이트닝 볼트를 배워야 하고, 라이트닝 볼트를 배우려면 먼저 스파크를 배워야 합니다. 위 순서에 없는 다른 스킬(힐링 등)은 순서에 상관없이 배울 수 있습니다. 따라서 스파크 → 힐링 → 라이트닝 볼트 → 썬더와 같은 스킬트리는 가능하지만, 썬더 → 스파크나 라이트닝 볼트 → 스파크 → 힐링 → 썬더와 같은 스킬트리는 불가능합니다. 선행 스킬 순서 skill과 유저들이 만든 스킬트리1를 담은 배열 skill_trees가 매개변수로 주어질 때, 가능한 스킬트리 개수를 retur..
[코딜리티(Codility)/Lesson4/파이썬3(python3)] MissingInteger 문제 This is a demo task.Write a function: def solution(A) that, given an array A of N integers, returns the smallest positive integer (greater than 0) that does not occur in A.For example, given A = [1, 3, 6, 4, 1, 2], the function should return 5.Given A = [1, 2, 3], the function should return 4.Given A = [−1, −3], the function should return ..
[프로그래머스/Level2/파이썬3(python3)] 멀쩡한 사각형 문제 가로 길이가 Wcm, 세로 길이가 Hcm인 직사각형 종이가 있습니다. 종이에는 가로, 세로 방향과 평행하게 격자 형태로 선이 그어져 있으며, 모든 격자칸은 1cm x 1cm 크기입니다. 이 종이를 격자 선을 따라 1cm × 1cm의 정사각형으로 잘라 사용할 예정이었는데, 누군가가 이 종이를 대각선 꼭지점 2개를 잇는 방향으로 잘라 놓았습니다. 그러므로 현재 직사각형 종이는 크기가 같은 직각삼각형 2개로 나누어진 상태입니다. 새로운 종이를 구할 수 없는 상태이기 때문에, 이 종이에서 원래 종이의 가로, 세로 방향과 평행하게 1cm × 1cm로 잘라 사용할 수 있는 만큼만 사용하기로 하였습니다.가로의 길이 W와 세로의 길이 H가 주어질..
[프로그래머스/Level2/파이썬3(python3)] 쇠막대기 문제 여러 개의 쇠막대기를 레이저로 절단하려고 합니다. 효율적인 작업을 위해서 쇠막대기를 아래에서 위로 겹쳐 놓고, 레이저를 위에서 수직으로 발사하여 쇠막대기들을 자릅니다. 쇠막대기와 레이저의 배치는 다음 조건을 만족합니다. - 쇠막대기는 자신보다 긴 쇠막대기 위에만 놓일 수 있습니다. - 쇠막대기를 다른 쇠막대기 위에 놓는 경우 완전히 포함되도록 놓되, 끝점은 겹치지 않도록 놓습니다. - 각 쇠막대기를 자르는 레이저는 적어도 하나 존재합니다. - 레이저는 어떤 쇠막대기의 양 끝점과도 겹치지 않습니다. 아래 그림은 위 조건을 만족하는 예를 보여줍니다. 수평으로 그려진 굵은 실선은 쇠막대기이고, 점은 레이저의 위치, 수직으로 그려진 점선 화살표..
[프로그래머스/Level2/파이썬3(python3)] 124나라의 숫자 문제 124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다. 124 나라에는 자연수만 존재합니다. 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다. 예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다. 10진법124 나라10진법124 나라 1161422721348224119245121041 자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요. 제한사항 n은 500,000,000이하의 자연수 입니다. 입출력 예 nresult 112234411 풀이 def solu..
생에 첫 화상면접 후기 구직 중 굉장히 좋아보이는 기업을 발견해서 지원을 했고 서류통과를 했고 그제 저녁에 화상면접을 봤다. 일단 본사가 미국에 있는 회사이고 우대사항에 영어 커뮤니케이션 능력이 있으면 좋다고 하니 아 이곳엘 가면 커리어와 함께 영어실력도 향상시킬 수 있겠구나 싶었다. 게다가 내가 하고 싶어하는 로봇을 다루는 회사고 또 django를 할 줄 아는 사람을 찾기도 했고... 그래서 음 가면 내 모든 고민들이 해결될 뿐더러 이 회사에도 공헌을 할 수 있겠다 싶었지만 면접을 조졌다. 화상면접은 이제 점점 더 보편화될 것이기 때문에 익숙해질 필요가 있고 다음에 실수하지 않기 위해 복기하는 의미로 기록을 남겨두려 한다. 일단 나는 올해 초에 퇴사하고 계획했던 모든 것들이 무너지면서 재정적인 타격을 ..