목록전체 글 (120)
할머니의 콤퓨타 도전기
long long 형의 범위를 벗어난 수들을 + 연산자를 이용해 덧셈을 하게되면 오버플로우 발생 따라서 굉장히 큰 수에 대해서는 문자배열을 이용해 덧셈 진행 Algorithm 문자 배열 (A, B) 2개를 뒤에서 부터 더해가며 새로운 문자 배열(result)에 저장 1번 과정을 진행하면서 올림 수(sum)을 계속 저장 문자 배열 A, B를 모두 순회하고 올림 수에 저장된 수가 없다면 result를 뒤집어 주고 종료 Ex. A = "12345", B = "666" 5 + 6 = 11 올림 수 1 result에 1 추가 sum = 1, result = "1" 4 + 6 + sum = 11 올림 수 1 result에 1 추가 sum = 1, result = "11" 3 + 6 + sum = 10 올림 수 1 ..
map 컨테이너의 반복자가 참조하고 있는 원소가 삭제되는 경우 위험 m.erase(it) 이후 m의 반복자인 it가 무효화됨. erase에 의해 반복자가 이미 지워진 요소를 가르킴. 따라서 ++연산자는 정의되지 않은 결과 불러옴 map m; ... for(auto it = m.begin(); it!=m.end(); it++){ if(it->second == value) m.erase(it); // runtime error } 따라서 아래와 같이 erase 호출 전 미리 반복자를 복사하고 erase 호출 map m; ... for(auto it = m.begin(); it!=m.end();){ if(it->second == value) m.erase(it++); else ++it; }
원반이 1개 시작점 'A'에서 도착지 'C'로 바로 옮김 원반이 2개 (원반이 1개일 때 처럼) 작은 원반을 B로 옮김 (원반이 1개일 때 처럼) 큰 원반을 C로 옮김 (원반이 1개일 때 처럼) 작은 원반을 다시 C로 옮김 원반이 3개 (원반이 2개일 때 )이용해서 (1번 원반, 2번 원반)을 A에서 B로 옮김 (원반이 1개일 때)이용해서 3번 원반을 옮김 (원반이 2개일 때)이용해서 (1번 원반, 2번 원반)을 B에서 C로 옮김 원반이 N개 (원반이 N-1개일 때 처럼) N-1개 원반을 B로 옮김 (원반이 1개일 때 처럼) 마지막 원반을 C로 옮김 (원반이 N-1개일 때 처럼) N-1개의 원반을 B에서 C로 옮김
Kruskal Algorithm 그래프 내의 모든 정점들을 가장 적은 비용으로 연결하기 위해 사용 (간선에 가중치가 포함) 그래프 내의 모든 정점을 포함하고 사이클이 없는 연결 선을 그렸을 때, 가중치의 합이 최소가 되는 상황을 구하고 싶을 때 사용 최소 신장 트리를 구하기 위한 알고리즘 신장 트리 (Spanning tree) 그래프에서 모든 정점을 포함하고 정점 간 서로 연결이 되며 사이클 (cycle)이 존재하지 않는 그래프 연결 관계에서 사이클 형성 안함 모든 정점이 포함되어 있으면서 모든 노드는 적어도 하나의 간선으로 연결되어 있음 신장 트리는 정점이 n개일 때, 간선이 n-1개 신장 트리들 중 가중치의 합이 최소가 되는 신장트리를 최소 신장 트리 (Minimum Spanning Tree, MST..
GCD int gcd(int a, int b) { if (b == 0) return a; else return gcd(b, a%b); } LCM LCM = (a*b)/GCD GCD(a,b) = G라고 둠. a = Gx, b = Gy (x, y는 서로소인 정수) 성립. 따라서 a, b의 합집합은 G, x, y 즉, a*b의 최소공배수는 G*x*y. a*b = G*G*x*y이므로 LCM = (a*b)/G = (a*b)/GCD