컴퓨터 기초
-
(컴퓨터공학) 데이터베이스는 B트리를 활용한 시스템이다.컴퓨터 기초/컴퓨터공학 2021. 5. 26. 09:09
데이터베이스는 정해진 방식으로 조직화된 데이터 모음이다. 데이터베이스 관리 시스템(DBMS)은 데이터베이스에 정보를 저장하고 읽어올 수 있게 해주는 프로그램이다. DBMS는 보통 맨 아래의 데이터 저장 매커니즘을 감싼 여러 계층의 인터페이스로 구성된다. 데이터베이스는 독일 컴퓨터과학자 루돌프 바이어(Rudolf Bayer)와 미국 컴퓨터과학자 에드 맥크레이트(Ed McCreight)가 보잉(Boeing)사에서 1971년 개발한 B트리라는 데이터 구조를 활용한 시스템이다. B트리는 균형 트리이지만 2진 트리는 아니다. B트리는 균형 2진 트리보다는 공간을 덜 효율적으로 사용하지만 성능이 더 낫고, 특히 디스크에 데이터를 저장할 때 균형 2진 트리보다 더 성능이 좋다. B트리는 메모리 아키텍처에 대한 이해가..
-
[정규표현식] 2018 카카오 신입공채 코딩테스트 - 다트게임컴퓨터 기초/알고리즘 2021. 2. 7. 18:56
2. 다트 게임(난이도: 하) 카카오톡 게임별의 하반기 신규 서비스로 다트 게임을 출시하기로 했다. 다트 게임은 다트판에 다트를 세 차례 던져 그 점수의 합계로 실력을 겨루는 게임으로, 모두가 간단히 즐길 수 있다. 갓 입사한 무지는 코딩 실력을 인정받아 게임의 핵심 부분인 점수 계산 로직을 맡게 되었다. 다트 게임의 점수 계산 로직은 아래와 같다. 다트 게임은 총 3번의 기회로 구성된다. 각 기회마다 얻을 수 있는 점수는 0점에서 10점까지이다. 점수와 함께 Single(S), Double(D), Triple(T) 영역이 존재하고 각 영역 당첨 시 점수에서 1제곱, 2제곱, 3제곱 (점수^1 , 점수^2 , 점수^3 )으로 계산된다. 옵션으로 스타상(*) , 아차상(#)이 존재하며 스타상(*) 당첨 시..
-
[알고리즘] 구현 ?컴퓨터 기초/알고리즘 2020. 12. 17. 21:47
코딩테스트 기출문제를 찾다보니 '구현'이라는 유형이 따로 있었다. 구현? 머리 속에 있는 알고리즘을 코드로 옮기는 것 사실 구현이라는 유형이라기 보다는, 그냥 우리가 알고리즘 문제를 풀 때 하는 행위들을 뜻한다고 보는게 보다 정확한 것 같다. 그럼에도 유형 중 '구현'이라 하면 아래와 같은 특성이 있다. 풀이를 떠올리는 것은 쉽지만 소스코드로 옮기기 어려운 문제들 유형 알고리즘은 간단한데 코드가 지나칠 만큼 길어지는 문제 실수 연산을 다루고, 특정 소수점 자리까지 출력해야 하는 문제 문자열을 특정한 기준에 따라서 끊어 처리해야 하는 문제 적절한 라이브러리를 찾아서 사용해야 하는 문제 사실 유형을 딱히 모르겠는 모든 문제는..구현이라고 봐도 무방해보인다. 참고 www.youtube.com/watch?v=g..
-
[알고리즘] 그리디 알고리즘/탐욕 알고리즘(Greedy Algorithm)컴퓨터 기초/알고리즘 2020. 12. 12. 18:37
지금 앞에 놓인 상황에서 최선의 선택을 고르는 것 이로 인해 최적의 해를 보장하지 않음 최선의 선택을 고르게 하기 위해 정당성 증명을 해야 함 아래처럼 문제를 보고 선택할 수 있는 가장 최적의 경우를 만들어줘야 함 (상세 내용은 아래 더보기를 통해 확인 가능) 더보기 그리디 알고리즘(욕심쟁이 알고리즘, Greedy Algorithm)이란 "매 선택에서 지금 이 순간 당장 최적인 답을 선택하여 적합한 결과를 도출하자" 라는 모토를 가지는 알고리즘 설계 기법이다. 예를 들어 5개의 도시를 모두 한번씩만 거쳐서 여행하는 경로 중 기름값을 아끼기 위해 가능하면 짧은 경로를 이용하고 싶다고 가정하자.[1] 이 문제를 해결하기 위해 몇가지 전략을 사용할 수 있다. 가능한 120가지의 조합을 모두 살펴봐서 그중 가장..