Study with book

    [백준]팰린드롬 만들기

    백준저지 [팰린드롬 만들기]https://www.acmicpc.net/problem/1254

    다익스트라(Dijkstra) 알고리즘 구현

    1.개요 드디어 다익스트라 알고리즘 구현을 끝냈다. 이 알고리즘을 연구하고 구현하는데 4일 정도가 소요된 것 같다. 다른 사이트들을 참고하면서 나만의 코드 스타일로 만들기 위해서 많은 노력을 했다. 다익스트라 알고리즘은 방향성과 가중치가 있는 그래프에서 최단거리를 구하는 알고리즘이다. 이번 다익스트라는 정점을 단순히 int값이 아닌 string값으로 입력받아 출력해주는 것을 목표로 구현했다. 다익스트라는 우선순위 큐를 이용해서 구현하는 것이 핵심이다. 방문한 정점에 인접한 정점들을 전부 우선순위 큐에 넣고 작은 가중치로 정렬된 우선순위 큐에서 빼내면서 최단거리를 구한다. 물로 그냥 큐를 사용해도 최종적으로는 최단거리로 갱신이되지만 우선순위 큐를 사용하면 이 갱신하는 작업을 없앤다. 다익스트라는 유명한 커..

    크루스칼(Kruscal) 알고리즘 구현

    [KruscalAlgorithm.cpp] 참고자료 http://makefortune2.tistory.com/39

    후기 표기법 계산(stack사용)

    1. 개요 - stack을 이용한 후기 표기법 계산은 쉬움 - 중위 표기법을 후위 표기법으로 바꾸는 코드가 까다롭게 느꼈음 - 풀이 방식 1) 문자열(char[])을 매개변수로 받는 함수 구성 2) double형 타입의 스택 선언(왜 double형이냐? 나누기 연산때문에) 3) 문자열 하나하나 따서 숫자면 스택에 넣고 문자면 스택에서 2개 빼내서 연산 후 다시 스택에 넣기 4) 문자열이 길이만큼 3번 반복 2. 코드 3. 정리 - char 타입의 문자를 isdigit()이란 함수를 통해서 숫자인지 아닌지를 구분할 수 있음 기억해 둘 것!! - 그리고 char타입이 숫자라면 X - '0' 를 통해서 정수형으로 변경할 수 있다는 것도 기억해 둘 것!! 참고자료 윤성우의 열혈 자료구조

    후위표기법 BinaryTree로 나타내기

    [MakeExpTree.h] [MakeExpTree.cpp] [MakeExpTreeMain.cpp] 참고자료 윤성우의 열혈 자료구조

    중위표기법을 후위표기법으로 변경(Stack 사용)

    "중위표기법을 후위표기법으로 변경(Stack 사용)" [InfixToPostfix.cpp] 참고자료 윤성우의 열혈 자료구조

    트리 구현하기

    [BinaryTree.h] [BinaryTree.cpp] [BinaryTreeMain.cpp] 참고자료 윤성우의 열혈 자료구조

    하노이타워 알고리즘

    1. 개요 - 하노이탑을 이해하면 보통 재귀함수를 완벽하게 이해할 수 있다고 한다. - 근데 솔직히 난 아직도 재귀가 낯설다. (더 파고들어가야할 듯) - 부분집합 출력하는 문제에도 재귀가 나오는데 부분집합 출력을 공부하면서 재귀가 잘 이해가지 않아서 하노이탑을 다시 살펴본다. 2. 문제 - N사에서 물어본 문제로 기억함 - HanoiTowerSol(5, 'A', 'B', 'C')인 경우 몇번 이동한 것일까?? 아래 해설 참고 3. 코드 4. 해설 HanoiTowerSol(1, 'A', 'B', 'C') 일 때 1번 이동이 있었음.(1번의 출력을 의미) HanoiTowerSol(2, 'A', 'B', 'C') 는 HanoiTowerSol(1, 'A', 'B', 'C')을 2번 호출한다는 것을 알 수 있음..

    개선된 피보나치 함수 구현

    1. 개요 - N사 필기시험에 나왔던 기억이 있다. - 피보나치 함수 개선하기 - 코드 내용 1) Fibo1은 변수 2개만 이용해서 피보나치 수열 구현 2) Fibo2는 다이나믹 프로그래밍 기법을 이용 3) Fibo3은 일반적인 피보나치 수열(매우 비효율적) 4) Fibo4는 메모제이션(memozation)기법 사용 2. 코드 3. 정리 - 다이나믹으로 구현하는 법은 알고있었는데 메모제이션 기법은 처음알게 되었다. - 꼭 기억하자!! - 그리고 메모제이션 기법은 재귀함수 구현에 있어서 많이 사용되는 기법!!! - 재귀의 효율을 극대화시켜줌!!

    [백준]동전 0

    백준저지 [동전 0]https://www.acmicpc.net/problem/11047 • 그리디 알고리즘을 요구하는 문제 • 핵심은 큰 금액부터 작은 금액으로 내려가면서 동전의 개수를 구해야 한다. • 푸는데 걸린 시간은 약 10분 정도 걸렸다. #include <iostream> using namespace std; int val[11]; int main(void) { int N, K, ans = 0, sum = 0; cin >> N >> K; for (int i = 1; i > val[i]; for (int i = N; i >= 1; i--) { if (val[i] < K) { while (sum