코딩테스트

    [실1] 1926 - 그림

    #include #include #include #include #include #include #include #include #include #include #include using namespace std; #define MAX_SIZE 502 int board[MAX_SIZE][MAX_SIZE]; bool visited[MAX_SIZE][MAX_SIZE]; int n = 0, m = 0; int dx[4]{ 1, 0, -1, 0 }; int dy[4]{ 0, 1, 0, -1 }; int main() { cin >> n >> m; for (int i = 0; i > board[i][j]; } int mx = 0; //..

    [실1] 2178 - 미로탐색

    특이사항) 좌표 (1,1)부터 (y,x)까지 이동하라는데 (1,1)부터 시작 시 로직이 복잡해지므로 (0,0)부터 시작 #include #include #include #include using namespace std;#define FAST_IO() ios::sync_with_stdio(0); cin.tie(0);#define y first#define x secondusing IntPair = pair;IntPair dir[]{ {1, 0}, // 상 {-1, 0}, // 하 {0, -1}, // 좌 { 0, 1 }, // 우};vector> map, dist;queue q;int y, x, cnt;void Bfs(){ while (!q.empty()) { auto cur = q.front..

    [실2] 11724 - 연결 요소의 개수

    Dfs로 주변 정점이 있는지 파악하고 있을 시 방문 여부 표시 없을 시 새로운 그래프로 간주 후 1개 증가 #include #include #include #include using namespace std;#define FAST_IO() ios::sync_with_stdio(0); cin.tie(0);#define y first#define x secondusing IntPair = pair;IntPair dir[]{ {1, 0}, // 상 {-1, 0}, // 하 {0, -1}, // 좌 { 0, 1 }, // 우};vector> graph;vector vis;int n, m;void Dfs(int idx){ vis[idx] = true; for (int i = 0; i > n >> m; ..

    [1] 신고 결과 받기

    vector solution(vector id_list, vector report, int k) { vector answer(id_list.size()); unordered_map report_map; unordered_map idx_map; stringstream ss; for (int i = 0; i > first >> second; report_map[second].insert(first); ss.clear(); } for (auto it : report_map) { if (it.second.size..

    [2] 기능 개발

    vector solution(vector progresses, vector speeds) { vector answer; map tmp_map; int size = progresses.size(); int* arr_days = new int[size] {0}; for (int i = 0; i < size; i++) { int count = 0; for (int j = progresses[i]; j = 100) { arr_days[i] = count; break; } } } for (int i = 1; i < size; i++) { if (arr_days[i] < arr_days[i - 1]) arr_days[i] = arr_days[i - 1]; } for (int i = 0; i < size; i++) ..

    [3] 여행경로

    vector answer; bool visited[100000001]; bool flag = false; int cnt = 0; void dfs(string cur, vector tickets) { if (cnt == tickets.size()) flag = true; answer.push_back(cur); for (int i = 0; i < tickets.size(); i++) { if (!visited[i] && tickets[i][0] == cur) { visited[i] = true; cnt++; dfs(tickets[i][1], tickets); if (!flag) { answer.pop_back(); visited[i] = false; } } } } vector solution(vector ..

    [3] N으로 표현

    int answer = 9; int goal = 0; void cal(int n, int cnt, int sum) { if (cnt > 8) return; if (sum == goal && answer > cnt) answer = cnt; int tmp = 0; for (int i = 1; i 8) ? -1 : answer; }

    [실2] 1012 - 유기농 배추

    x y로 푸는 사람들한텐 안맞을듯 #include #include #include using namespace std;#define FAST_IO() ios::sync_with_stdio(0); cin.tie(0);pair dir[]{ {1, 0}, // 상 {-1, 0}, // 하 {0, -1}, // 좌 { 0, 1 }, // 우};vector> map;int t, h, w, k;void Dfs(int y, int x){ for (int i = 0; i = h || ny = w || nx > t; while (t--) { int cnt = 0; cin >> h >> w >> k; map = vector>(h, vector(w)); while (k--) { int a, b;..

    [실2] 4963 - 섬의 개수

    #include #include using namespace std;#define FAST_IO() ios::sync_with_stdio(0); cin.tie(0);pair dir[]{ {1, 0}, // 상 {-1, 0}, // 하 {0, -1}, // 좌 { 0, 1 }, // 우 // 대각선 {1, 1}, {-1, -1}, {1, -1}, {-1, 1},};vector> map;int h, w;void Dfs(int y, int x){ for (int i = 0; i = h || ny = w || nx > w >> h; if (!w && !h) break; //map.resize(h, vector(w)); map = vector>(h, vector(w)); for (i..