목록분류 전체보기 (559)
알고리즘 모음(C++)
문제 링크입니다. https://www.acmicpc.net/problem/12834 12834번: 주간 미팅첫째 줄에 KIST 기사단 팀원의 수 N, 장소의 수 V, 도로의 수 E가 주어진다. (N ≤ 100, V ≤ 1000, E ≤ 10000) 둘째 줄에 KIST의 위치 A와 씨알푸드의 위치 B가 주어진다. (1 ≤ A, B ≤ V) 셋째 줄에 팀원 N명의www.acmicpc.netN번의 다익스트라를 이용하는 문제입니다.팀원 N명의 집에서 각자 출발할 때, 모든 사람의 최단 거리의 합을 구하는 문제입니다. 최단 거리를 구하는 방법은 X번 사람의 집에서 KIST까지의 거리 + 씨알푸드까지의 거리 입니다. 만약, 거리가 갈 수 없다면 -1로 바꿔서 계산하면 됩니다. 문제를 푸는 방법은 간단하게 N번의 ..
불과 몇년 전만해도 플레티넘3은 커녕 플레티넘까지도 못가고 끝날 것이라고 생각했었을 때가 있었습니다. 꾸준히 하다보니 플레티넘5 를 올라갈 수 있었고, 어느샌가 플레티넘4 까지 왔었습니다. 이제 진짜 올라갈 때까지 올라갔구나, 내 실력에 비해서 더 높은 티어인것 같다고 생각했지만, 결국은 3까지 올라왔습니다. 지금은 이번 티어가 마지막을 것이라고 생각하지만, 나중에 보면 다를 수도 있을것 같다는 생각을 합니다. 알고리즘 분아에서 백준 상위 2%안에 든다고 적혀져있지만, 아직 그정도 실력은 아니고 많이 부족함을 느끼고 있습니다. 문제들을 풀면서 프로그레밍에 크게 재능은 없다고 생각하게 되고, 왜 이정도 밖에 못할까라는 생각을 가져본 적도 많습니다. 그렇지만, 지금까지 막히는 문제가 있으면 실마리가 잡힐 때..
문제 링크입니다. https://www.acmicpc.net/problem/9694 9694번: 무엇을 아느냐가 아니라 누구를 아느냐가 문제다맨위 첫 번째 줄에 T(1 n_cost){ parent[xx] = x; //자신과 연결된 부모 저장 Distance[xx] = n_cost; q.push({-Distance[xx], xx}); } } } } void solve(int num){ reset_array(); Dijstra(); if(Distance[M-1] != INF){ vector way; way.clear(); for(int i = M-1; i != 0; i = parent[i]){ // 저장된 부모들을 찾는다. way.push_back(i); } way.push_back(0); cout cost..
문제 링크입니다. https://www.acmicpc.net/problem/3036 3036번: 링출력은 총 N-1줄을 해야 한다. 첫 번째 링을 제외한 각각의 링에 대해서, 첫 번째 링을 한 바퀴 돌리면 그 링은 몇 바퀴 도는지 기약 분수 형태 A/B로 출력한다.www.acmicpc.net유클리드 호제법을 이용한 문제입니다.첫번째 링의 길이를 기준으로 다른 링들과의 최대 공약수를 구해줍니다. -> 이때 유클리ㄷ, 호제법이 이용됩니다. 최대 공약수를 구해줬다면, 값을 바탕으로 링이 도는 횟수를 출력해주면 됩니다. 자세한 것은 코드를 참고해주세요.#define _CRT_SECURE_NO_WARNINGS #include using namespace std; int N; int ring[101]; int Uc..
문제 링크입니다. https://www.acmicpc.net/problem/5063 5063번: TGN첫째 줄에 테스트 케이스의 개수 N이 주어진다. 다음 N개의 줄에는 3개의 정수 r, e, c가 주어진다. r은 광고를 하지 않았을 때 수익, e는 광고를 했을 때의 수익, c는 광고 비용이다. (-106 ≤ r,e ≤ 106www.acmicpc.net 자세한 것은 코드를 참고해주세요.#define _CRT_SECURE_NO_WARNINGS #include using namespace std; int N; int main(){ cin.tie(0); cout.tie(0); cin >> N; for(int i = 1; i > x >> y >> cost; if(x < y - cost){ cout
문제 링크입니다. https://www.acmicpc.net/problem/1267 1267번: 핸드폰 요금동호가 저번 달에 이용한 통화의 개수 N이 주어진다. N은 20보다 작거나 같은 자연수이다. 둘째 줄에 통화 시간 N개가 주어진다. 통화 시간은 10,000보다 작거나 같은 자연수이다.www.acmicpc.net간단한 조건문 문제입니다.문제에 주어진 조건에 따라 값을 저장한 뒤, 마지막에 비교해주면 됩니다. 자세한 것은 코드를 참고해주세요.#define _CRT_SECURE_NO_WARNINGS #include using namespace std; int N, Y, M; int main(){ cin.tie(0); cout.tie(0); cin >> N; for(int i = 1; i > x; Y +..
문제 링크입니다. https://www.acmicpc.net/problem/16118 16118번: 달빛 여우첫 줄에 나무 그루터기의 개수와 오솔길의 개수를 의미하는 정수 N, M(2 ≤ N ≤ 4,000, 1 ≤ M ≤ 100,000)이 주어진다. 두 번째 줄부터 M개의 줄에 걸쳐 각 줄에 세 개의 정수 a, b, d(1 ≤ a, b ≤ N, a ≠ bwww.acmicpc.net다익스트라를 사용하는 문제였습니다.달빛 여우와 늑대가 어느 정점을 갈 때의 최소 비용이 여우가 더 적은 정점의 개수를 찾는 문제입니다. 주의할 점은 여우는 주어진 비용으로만 가지만, 늑대는 (비용/2) -> (비용*2) -> (비용/2) ..... 의 방법으로 가게 됩니다. 그렇다면 다른 정점까지의 여우의 최솟값, 늑대의 최솟값..
문제 링크입니다. https://www.acmicpc.net/problem/2645 2645번: 회로배치회로를 n×n의 격자 판에 배치하려고 한다. 여기서 각 격자(정사각형 칸)는 범위 밖에 있는 격자를 제외하고 상, 하, 좌, 우 4개의 이웃 격자를 갖는다. 회로는 시작과 끝이 있는 연속된 이웃 격자www.acmicpc.net복잡했던 다익스트라 문제였습니다.A와 B를 최소 비용으로 이을려고 할 때의 비용을 구하는 문제입니다. 격자판 위에 다른 회로가 있을 수도 있습니다. A와 B를 이을 때, 선이 다른 회로의 위에 있을 경우, K의 비용이 들어가고, 다른 회로가 없을 경우에는 1의 비용이 들어갑니다. 따라서, 처음으로는 다른 회로가 어떻게 있는지를 구하는 것이 중요합니다. 입력에서 (3, 3, 9, 3..
문제 링크입니다. https://www.acmicpc.net/problem/2398 2398번: 3인통화첫 번째 줄에는 두 개의 정수가 있다. 첫 번째 정수 n(1 ≤ n ≤ 1000) 는 전화망에 있는 스위치의 개수를 나타내며, 두 번째 정수 m은 스위치와 스위치를 연결하는 링크의 개수를 나타낸다. 단, 같은www.acmicpc.net다익스트라와 백트래킹을 이용한 문제였습니다.3자 통화를 할 때 드는 최소 비용과 이때의 연결된 링크의 갯수, 어떤 링크인지를 출력하는 문제입니다. 먼저 3자 통화를 하는데 필요한 최소 비용을 구하는 것부터 해보겠습니다. N개의 정점에서 세명의 위치까지의 최소거리를 구한 후 값을 더해 각 정점에서 출발했을 때의 값을 각각 구한다면 N(
문제 링크입니다. https://www.acmicpc.net/problem/1884 1884번: 고속도로첫 줄에 여러분이 준비해 둔 교통비 K가 주어진다. (0≤K≤10,000) 둘째 줄과 셋째 줄에는 각각 도시의 숫자 N과 도로의 숫자 R이 주어진다. (2≤N≤100, 1≤R≤10,000) 이후 R개의 줄에 각 도로의 정보가 www.acmicpc.net다익스트라를 이용한 문제입니다. 제한된 비용 안으로 목적지까지 가려고 할 때, 최소 거리를 구하는 문제입니다. 여기서 생각해볼 것은, 같은 정점이라도 다른 비용으로 방문할 수 있습니다. 그렇다면 항상 적은 비용으로 도달하는 경우가 최고의 경우이냐 하면 그건 아닙니다. 따라서, 같은 정점이라도 다른 비용으로 도착할 경우를 생각해, 2차원 배열을 이용해 모든..
문제 링크입니다. https://www.acmicpc.net/problem/24042 24042번: 횡단보도당신은 집으로 가는 도중 복잡한 교차로를 만났다! 이 교차로에는 사람이 지나갈 수 있는 $N$ 개의 지역이 있고 그 지역 사이를 잇는 몇 개의 횡단보도가 있다. 모든 지역은 횡단보도를 통해 직, www.acmicpc.net1번에서 N번 정점까지 횡단보도를 통해 이동할 때 최소 이동 시간을 구하는 문제입니다. 문제에서 주의할 점은 횡단보도가 한번에 바뀌는 것이 아닌, 번호 순서대로 바뀐다는 점입니다. 1번 -> 2번 -> ……… -> M번 횡단보도 순으로 바뀝니다. 여기서 생각해봐야 할 점이 5번 도로를 지났다고 했을 때, 7번 도로를 건넌다고 한다면 2분을 기다린 후 건너면 됩니다. 그렇다면 5번 ..
문제 링크입니다. https://www.acmicpc.net/problem/2307 2307번: 도로검문그림 1은 어떤 도시의 주요 지점과 그 지점들 간의 이동시간을 나타낸 그래프이다. 그래프의 노드는 주요 지점을 나타내고 두 지점을 연결한 도로(에지)에 표시된 수는 그 도로로 이동할 때 걸리www.acmicpc.net다익스트라를 사용해 푸는 문제입니다.도로를 하나 제한했을 때, 지연시킬 수 있는 최대 시간을 구하는 문제입니다. 모든 길을 제한한다고 한다면, 도로의 수가 5,000개이기에 다익스트라를 5000개를 확인을 해야합니다. 따라서, 다른 방법을 이용해야 하는데, 생각을 해본다면, 최단 거리일 떄의 길을 제외하고 제한한다면, 값은 항상 최단 거리의 값이 될 것입니다. 문제에서 주어진 그림으로 확인..