일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- #알고리즘 #백준 #1260 #백준1260 #algorithm #baekjoon #baekjoon1260 #Java
- #알고리즘 #백준 #15683 #백준15683 #algorithm #baekjoon #baekjoon15683 #C++
- #알고리즘 #백준 #14888 #백준14888 #algorithm #baekjoon #baekjoon14888 #C++
- #알고리즘 #백준 #17140 #백준17140 #algorithm #baekjoon #baekjoon17140 #C++
- #알고리즘 #백준 #1525 #백준1525 #algorithm #baekjoon #baekjoon1525 #C++
- #알고리즘 #백준 #2580 #백준2580 #algorithm #baekjoon #baekjoon2580 #Java
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #문자열압축 #programmers #C++
- #알고리즘 #백준 #12094 #백준12094 #algorithm #baekjoon #baekjoon12094 #C++
- 클린코드
- #알고리즘 #백준 #15684 #백준15684 #algorithm #baekjoon #baekjoon15684 #C++
- #알고리즘 #백준 #5214 #백준5214 #algorithm #baekjoon #baekjoon5214 #C++
- CleanCode
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #괄호변환 #programmers #C++
- #알고리즘 #백준 #3190 #백준3190 #algorithm #baekjoon #baekjoon3190 #C++
- 개발서
- #알고리즘 #백준 #4386 #백준4386 #algorithm #baekjoon #baekjoon4386 #C++
- #알고리즘 #백준 #17837 #백준17837 #algorithm #baekjoon #baekjoon17837 #C++
- #알고리즘 #백준 #1793 #백준1793 #algorithm #baekjoon #baekjoon1793 #C++
- #알고리즘 #백준 #17472 #백준17472 #algorithm #baekjoon #baekjoon17472 #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #블록이동하기 #programmers #C++
- #알고리즘 #백준 #17406 #백준17406 #algorithm #baekjoon #baekjoon17406 #C++
- #알고리즘 #백준 #2573 #백준2573 #algorithm #baekjoon #baekjoon2573 #C++
- #알고리즘 #백준 #2616 #백준2616 #algorithm #baekjoon #baekjoon2616 #Java
- 스레드 #동시성 #thread #process #
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #외벽점검 #programmers #C++
- #알고리즘 #백준 #17136 #백준17136 #algorithm #baekjoon #baekjoon17136 #C++
- 책리뷰
- #알고리즘 #백준 #2352 #백준2352 #algorithm #baekjoon #baekjoon2352 #C++
- 개발자취미
- #알고리즘 #백준 #1987 #백준1987 #algorithm #baekjoon #baekjoon1987 #Java
Archives
- Today
- Total
개발자 일기장.
백준 17140. 이차원배열과 연산 본문
이차월배열과 연산
Problem?
문제 : https://www.acmicpc.net/problem/17140
Solution
문제 구현 문제
- row_size와 col_size를 비교한다. row_size가 col_size보다 크거나 같으면 R연산을 진행하고 그외에는 C연산을 진행한다.
- 연산내에서는 반복횟수를 확인하고 횟수와 숫자 쌍을 vector형태로 저장후 sorting한후에 다시 board에 넣어준다.
Code
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
#define MAX 100
int r, c, k, ans = -1;
int row_size, col_size;
int board[MAX + 1][MAX + 1];
int main(int argc, const char* argv[]) {
// input
cin >> r >> c >> k;
for (int i = 1; i <= 3; i++)
for (int j = 1; j <= 3; j++)
scanf("%d", &board[i][j]);
row_size = 3;
col_size = 3;
// solution
for (int cnt = 0; cnt <= MAX; cnt++) {
// end state
if (board[r][c] == k) {
ans = cnt;
break;
}
if (row_size >= col_size) { // R, row >= colr
for (int i = 1; i <= row_size; i++) {
vector<int> board_count(MAX + 1);
vector<pair<int, int>> board_set;
for (int j = 1; j <= col_size; j++) board_count[board[i][j]]++;
for (int j = 1; j <= MAX; j++)
if (board_count[j])
board_set.push_back({ board_count[j], j });
for (int j = 0; j <= col_size; j++) board[i][j] = 0;
sort(board_set.begin(), board_set.end());
int j_pos = 1;
for (int j = 0; j < board_set.size(); j++) {
board[i][j_pos++] = board_set[j].second;
board[i][j_pos++] = board_set[j].first;
}
j_pos--;
if (j_pos > MAX)
col_size = MAX;
else
col_size = max(col_size, j_pos);
}
}
else { // C, row < col
for (int j = 1; j <= col_size; j++) {
vector<int> board_count(MAX + 1);
vector<pair<int, int>> board_set;
for (int i = 1; i <= row_size; i++) board_count[board[i][j]]++;
for (int i = 1; i <= MAX; i++)
if (board_count[i])
board_set.push_back({ board_count[i], i });
for (int i = 1; i <= row_size; i++) board[i][j] = 0;
sort(board_set.begin(), board_set.end());
int i_pos = 1;
for (int i = 0; i < board_set.size(); i++) {
board[i_pos++][j] = board_set[i].second;
board[i_pos++][j] = board_set[i].first;
}
i_pos--;
if (i_pos > MAX)
row_size = MAX;
else
row_size = max(row_size, i_pos);
}
}
}
// output
cout << ans << "\n";
return 0;
}
- 구현 문제.
- 틀려도 연습문제는 다맞고 문제를 확인했을 때 어디서 틀리는지 알수가 없어서 초반에 고생했다.
'취업 > Algorithm.' 카테고리의 다른 글
[2020카카오공채] 괄호 변환 (0) | 2020.04.11 |
---|---|
백준 17837. 새로운 게임2 (0) | 2020.04.11 |
백준 15684. 사다리 조작 (0) | 2020.04.11 |
백준 17472. 다리만들기2 (0) | 2020.04.10 |
백준 17406. 배열 돌리기4 (0) | 2020.03.28 |