알고리즘
-
Algorithm Note
Dynamic Programming(DP) 알고리즘 - 동적프로그래밍, Python으로 푸는 피보나치
Dynamic Programming 큰 문제를 나누어 작은 문제로 푸는 것 하나의 문제는 단 한 번의 풀이만 한다. Dynamic Programming 과 Recursion(재귀)의 차이점 DP와 재귀는 얼핏보면 '같은 문제가 반복적으로 일어나는 점' 에서 비슷하다고 생각할 수 있다. 하지만, 큰 차이점은 일반적인 재귀를 단순히 사용하면 동일한 작은 문제들이 여러 번 반복 되어 비효율적인 계산될 수 있다는 것이다. 가장 대표적인 예시는 피보나치 함수이다. DP 조건 두 가지 조건을 만족해야 한다. 1. 같은 문제가 반복적으로 발생 2. 최적 부분 구조 동일한 작은 문제들이 반복적으로 일어날 때, 같은 문제는 항상 정답도 같다. 즉, 중복 사용이 가능하다. DP 문제 풀이 방법 모든 작은 문제는 한 번..
-
Algorithm Note
알고리즘 - Greedy (탐욕 알고리즘, 욕심쟁이 알고리즘), 최적해 찾기
Greedy Alogrithm Greedy는 사전적인 의미로 '탐욕스러운', '욕심많은' 이라는 뜻을 가지고 있다. 탐욕 알고리즘 또는 욕심쟁이 알고리즘 라고도 불린다. 미래를 생각하지 않고 선택의 순간마다 당장 눈앞에 보이는 최적의 선택을 하는 기법 각 단계에서 최선의 선택을 한 것이 전체적으로도 최선이길 바라는 알고리즘 그리디 알고리즘 해결 방법 선택 : 현재 상태에서 최적의 해답 선택 적절성 검사 : 선택된 답이 문제의 조건을 만족하는 지 확인 해답 검사 : 원래의 문제가 해결되었는지 검사하고, 해결되지 않았다면 선택 절차로 돌아가 위의 과정을 반복한다. 그리디 알고리즘 조건 그리디 알고리즘을 적용하기 위해서는 2가지 조건을 성립해야 한다. 1. 탐욕적 선택 속성 (Greedy Choice Prop..
-
Algorithm Note
알고리즘 - Stack, Queue (선형 큐, 원형 큐, 알고리즘 코드)
스택 '먼저 들어간 것이 나중에 나오는 자료구조' Last In First Out (LIFO) 구조이다. 스택은 배열과 연결 리스트로 나타낼 수 있다. 스택의 구성 - 상단 (top) : 스택에서 제일 나중에 입력된 데이터의 위치 - 하단 (bottom) : 스택에서 제일 먼저 입력된 데이터의 위치 - 요소 (element) : 스택에 저장되는 데이터 그 자체 - 공백 (empty stack) : 아무런 데이터도 갖고 있지 않은 스택 스택의 연산 push() : 스택에 데이터를 추가한다. pop() : 스택에서 데이터를 삭제한다. is_empty(s) : 스택이 공백상태인지 검사한다. is_full(s) : 스택이 포화상태인지 검사한다. create() : 스택을 생성한다. peek(s) : 요소를 스택..
조회수가 많은 글
-
명품 운영체제
[명품 운영체제] - Chapter02 연습문제 + 복합문제 풀이
생능출판 - 황기태 - 명품 운영체제 명품 운영체제 연습문제 Chapter 02 1. 컴퓨터 시스템에서 주소를 발생시킬 수 있는 하드웨어를 있는 대로 골라라 CPU 메모리 캐시 메모리 디스크 📝 CPU는 컴퓨터에서 기억, 해석, 연산, 제어라는 4대 주용 기능을 관할하는 장치이다. 컴퓨터의 가장 핵심 장치이며, 전원이 공급될 때 작동을 시작한다. 메모리에 적재된 프로그램을 실행하고 컴퓨터 시스템에서 주소를 발생시키는 하드웨어이다. 2. CPU의 주소 선이 총 24개 있다면 이 CPU가 액세스할 수 있는 메모리의 최대 크기는? 1MB 16MB 1GB 2GB 📝 CPU의 주소 선이 24개면 2^24개의 주소를 표현할 수 있다. 주소 선의 개수는 CPU가 직접 액세스할 수 있는 메모리의 크기를 결정한다. 각 ..
-
ADsP
[ADsP 데이터분석 준전문가] - 핵심 내용 요약 정리 (4) - PART 4. 데이터 분석 기획
[데이터 분석 기획 - 1. 분석 과제 정의] 1. 분석 기회 발굴 분석 기회 : 기업의 전사 또는 개별 업무별 의사 결정 포인트에 활용할 수 있는 분석 후보 접근 방식 톱다운 (Top-Down) 방식 : 비즈니스 모델로부터 경쟁력 향상을 도모할 수 있는 분석 기회를 발굴하고 전사 분석 체계 구현을 위한 거버넌스 체계 전반을 다룬다. 보텀업 (Bottom-Up) 방식 : 주제별 분석 기회를 구현 분석 기회 발굴을 위한 3가지 방법 비즈니스 모델 분석을 통한 Top Down 방식 : 기업의 비즈니스 모델을 분석하여 경쟁력 강화를 위한 핵심 분석기회 식별 대상 프로세스 선정, 분석을 통한 Bottom Up Path Finding 방식 : 특정 대산 프로세서를 선정한 후 주제별로 분석기회를 식별 분석 유즈케이..
-
iOS
iOS - 2023년 최신 iOS 개발 동향과 업데이트 (feat. WWDC 2023)
2023년 iOS 앱 개발 동향과 최신 기술에 대해 관심을 가지고 알아보려고 한다. 지난 6월에는 WWDC 2023에서 Apple의 많은 기술과 업데이트, 그리고 신제품까지 공개되었다. 사실 나에게 첫 WWDC 관람이였는데 다시 한 번 Apple의 매력에 빠져버렸다. 아마 애플 생태계를 사랑하는 사람들과 함께 관전을 해서 더 특별하고 강조되었던 것 같다. 특히 9년 만에 발표된 Vision Pro는 아마 많은 분들이 예측하고 기대했을 것 같다. Vision Pro는 3D 환경에서 경험을 자유롭게 상상하며 둘러볼 수 있고 실험할 수 있다. 1. iOS 17 Apple은 매년 새로운 iOS를 발표한다. 올해 2023년에는 iOS 17이 업데이트 될 예정이다. WidgetKit을 통해 상호작용 기능 및 애니메..
-
iOS
[iOS - Network] iOS에서 서버 통신 하는 방법 (URL Session, Alamofire, Moya)
서버 통신이란?💡 클라이언트(프론트엔드)와 서버(백엔드)가 서로 데이터를 주고 받는 것 개인 프로젝트 같은 경우에는 많아봤자 10개 정도의 데이터를 다루기 때문에 Dummy를 활용해서 넣을 수 있지만, 날씨 앱을 예시로 들면 전국의 지역별 날씨, 시간대별, 강수확률, 최고 온도, 최저 온도 등등…. 너무 많은 데이터들을 dummy로 다루는 건 불가능한 일이다. 때문에, 클라리언트에서 필요한 정보가 있을 때마다 서버에게 요청을 하고, 서버는 그 요청에 맞는 데이터를 클라이언트에게 전달하는 과정을 거친다. 이를 서버 통신이라고 한다. iOS에서는 대표적으로 URLSession, Alamofire, Moya로 서버 통신을 할 수 있다.URL Session💡 - Swift에서는 URLSession을 이용하..
-
🤖 Computer Vision
컴퓨터 비전 영상처리 - 에지 검출 (디지털 영상의 미분, 계단 에지, 램프 에지, 스무딩 기법, 소벨 연산자, 영교차 찾기)
영상처리에서 에지란? 영상의 명암, 컬러, 또는 텍스처와 같은 특성이 급격히 변하는 지점이다. 에지는 '테두리' 라는 뜻을 가지며 물체의 '경계'를 표시해 준다. 매칭에 용이한 선분이나 곡선으로 변환이 가능하다. 에지의 한계 실종된 에지(거짓 부정)와 거짓 에지(거짓 긍정)가 발생한다. 디지털 영상의 미분 1차원 수학에서 변화를 측정하는 기초 이론은 미분이다. 연속 공간에서의 미분은 도함수를 구할 수 있는데, x값이 미세하게 증가했을 때 연속 함수가 어떻게 변화하는지를 측정해준다. 하지만 컴퓨터 비전이 다루는 디지털 영상은 이산 공간에서 정의된다. 따라서 이산 공간에서 도함수를 근사화하는 방법을 고안해야 한다. 위의 f'(x) 식을 보면 마스크[-1][1]로 영상 f를 컨볼루션 하는 것과 같다. 3-2의..