일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #문자열압축 #programmers #C++
- 개발서
- #알고리즘 #백준 #15684 #백준15684 #algorithm #baekjoon #baekjoon15684 #C++
- #알고리즘 #백준 #14888 #백준14888 #algorithm #baekjoon #baekjoon14888 #C++
- #알고리즘 #백준 #3190 #백준3190 #algorithm #baekjoon #baekjoon3190 #C++
- CleanCode
- #알고리즘 #백준 #5214 #백준5214 #algorithm #baekjoon #baekjoon5214 #C++
- #알고리즘 #백준 #17140 #백준17140 #algorithm #baekjoon #baekjoon17140 #C++
- #알고리즘 #백준 #4386 #백준4386 #algorithm #baekjoon #baekjoon4386 #C++
- 스레드 #동시성 #thread #process #
- #알고리즘 #백준 #1793 #백준1793 #algorithm #baekjoon #baekjoon1793 #C++
- #알고리즘 #백준 #17406 #백준17406 #algorithm #baekjoon #baekjoon17406 #C++
- #알고리즘 #백준 #2580 #백준2580 #algorithm #baekjoon #baekjoon2580 #Java
- #알고리즘 #백준 #2352 #백준2352 #algorithm #baekjoon #baekjoon2352 #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #외벽점검 #programmers #C++
- 개발자취미
- #알고리즘 #백준 #1260 #백준1260 #algorithm #baekjoon #baekjoon1260 #Java
- #알고리즘 #백준 #17472 #백준17472 #algorithm #baekjoon #baekjoon17472 #C++
- #알고리즘 #백준 #15683 #백준15683 #algorithm #baekjoon #baekjoon15683 #C++
- #알고리즘 #백준 #1987 #백준1987 #algorithm #baekjoon #baekjoon1987 #Java
- 클린코드
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #블록이동하기 #programmers #C++
- #알고리즘 #백준 #2616 #백준2616 #algorithm #baekjoon #baekjoon2616 #Java
- #알고리즘 #백준 #17136 #백준17136 #algorithm #baekjoon #baekjoon17136 #C++
- #알고리즘 #백준 #1525 #백준1525 #algorithm #baekjoon #baekjoon1525 #C++
- 책리뷰
- #알고리즘 #백준 #17837 #백준17837 #algorithm #baekjoon #baekjoon17837 #C++
- #알고리즘 #백준 #12094 #백준12094 #algorithm #baekjoon #baekjoon12094 #C++
- #알고리즘 #백준 #2573 #백준2573 #algorithm #baekjoon #baekjoon2573 #C++
- #알고리즘 #algorithm #프로그래머스 #2020카카오공채 #괄호변환 #programmers #C++
Archives
- Today
- Total
개발자 일기장.
백준 14888. 연산자 끼워넣기 본문
14888 연산자 끼워넣기
문제 알고리즘
- 순열문제
풀이방법
- 덧셈, 뺄셈, 곱셈, 나눗셈의 횟수를 받아 이를 vector형태로 바꾼다.
- 순열을 돌리면서 최대값과 최소값을 계산한다.
- 핵심 코드
#include <iostream>
#include <vector>
#include <algorithm>
#include <limits.h>
using namespace std;
// static
const int MAX = 11;
// variable
int N;
int numList[MAX], signCount[4];
vector<int> signList;
int max_num = INT_MIN, min_num = INT_MAX;
void solution( ) {
do {
int sum = numList[0];
for (int i = 0; i < signList.size(); i++) {
switch (signList[i])
{
case 0:
sum += numList[i + 1];
break;
case 1:
sum -= numList[i + 1];
break;
case 2:
sum *= numList[i + 1];
break;
case 3:
sum /= numList[i + 1];
break;
}
}
if (sum > max_num)
max_num = sum;
if (sum < min_num)
min_num = sum;
} while (next_permutation(signList.begin(), signList.end()));
}
int main() {
// input
cin >> N;
for (int i = 0; i < N; i++)
scanf("%d", &numList[i]);
for (int i = 0; i < 4; i++)
scanf("%d", &signCount[i]);
// solution
for (int i = 0; i < 4; i++)
for (int j = 0; j < signCount[i]; j++)
signList.push_back(i);
solution();
// output
cout << max_num << "\n" << min_num << "\n";
return 0;
}
문제 후 느낀점
- 쉬운 순열문제.
'취업 > Algorithm.' 카테고리의 다른 글
백준 1260. DFS, BFS (0) | 2020.05.30 |
---|---|
[2020 KAKAO BLIND RECRUITMENT] 외벽 점검 (0) | 2020.05.02 |
백준 2573. 빙산 (0) | 2020.05.01 |
[2020카카오공채] 괄호 변환 (0) | 2020.04.11 |
백준 17837. 새로운 게임2 (0) | 2020.04.11 |