목록백준 (183)
Study hard
https://www.acmicpc.net/problem/14888 14888번: 연산자 끼워넣기 첫째 줄에 수의 개수 N(2 ≤ N ≤ 11)가 주어진다. 둘째 줄에는 A1, A2, ..., AN이 주어진다. (1 ≤ Ai ≤ 100) 셋째 줄에는 합이 N-1인 4개의 정수가 주어지는데, 차례대로 덧셈(+)의 개수, 뺄셈(-)의 개수, �� www.acmicpc.net [풀이] 주어진 연산자를 나열하는 모든 경우에 대해 계산을 하고, 최소값과 최대값을 저장한다. #include #include #include //min,max using namespace std; int N; vectorA(11);//N개의 수 int op[4];//각 연산자의 개수 (0:+, 1:-, 2:*, 3:/) vectorv;..
https://www.acmicpc.net/problem/14225 14225번: 부분수열의 합 수열 S가 주어졌을 때, 수열 S의 부분 수열의 합으로 나올 수 없는 가장 작은 자연수를 구하는 프로그램을 작성하시오. 예를 들어, S = [5, 1, 2]인 경우에 1, 2, 3(=1+2), 5, 6(=1+5), 7(=2+5), 8(=1+2+5)을 만들 � www.acmicpc.net [풀이] 원소가 1개 이상인 모든 조합에 대해 원소값들의 합을 구하고, 만들 수 있는 자연수 i에 대해 canMake[i]를 true로 저장한다. 마지막에 1부터 시작하여 만들 수 없는 자연수가 나올 때까지 for문을 돌린다. #include #include using namespace std; int N;//수열 S의 크기 ..
https://www.acmicpc.net/problem/1182 1182번: 부분수열의 합 첫째 줄에 정수의 개수를 나타내는 N과 정수 S가 주어진다. (1 ≤ N ≤ 20, |S| ≤ 1,000,000) 둘째 줄에 N개의 정수가 빈 칸을 사이에 두고 주어진다. 주어지는 정수의 절댓값은 100,000을 넘지 않는다. www.acmicpc.net [풀이] 원소가 1개 이상인 모든 조합에 대해 원소의 합을 구하여 그 값이 S가 되면 카운트하는 방법으로 풀었다. ※처음 조합 구하는 함수를 호출할 때는 원소를 아무것도 고르지 않은 경우이므로 조건식을 이용해 그냥 통과하게 해야한다. #include #include using namespace std; int N, S; int ans = 0;//경우의 수 vec..
https://www.acmicpc.net/problem/6603 6603번: 로또 문제 독일 로또는 {1, 2, ..., 49}에서 수 6개를 고른다. 로또 번호를 선택하는데 사용되는 가장 유명한 전략은 49가지 수 중 k(k>6)개의 수를 골라 집합 S를 만든 다음 그 수만 가지고 번호를 선택하는 www.acmicpc.net [풀이] k개의 수로 구성된 집합 S에서 6개의 수를 고르는 모든 방법을 구하는 문제이다. 고르는 수는 중복되지 않고, 순서를 바꾸는 경우는 세지 않으므로 조합을 구하면 된다. #include #include using namespace std; int k; vectorS(13);//집합 S bool check[50];//선택한 숫자 true //조합 구하기 void getSet..
https://www.acmicpc.net/problem/10971 10971번: 외판원 순회 2 첫째 줄에 도시의 수 N이 주어진다. (2 ≤ N ≤ 10) 다음 N개의 줄에는 비용 행렬이 주어진다. 각 행렬의 성분은 1,000,000 이하의 양의 정수이며, 갈 수 없는 경우는 0이 주어진다. W[i][j]는 도시 i에서 j www.acmicpc.net [풀이] 가능한 모든 경로에 대한 비용들을 비교하여 최솟값을 구하였다. 방문하는 도시의 순서에 따라 최종 비용이 달라지므로 순열을 사용하였다. 마지막으로 방문하는 도시에서 출발한 도시로 갈 수 있는지 확인해줘야 한다. 모든 도시가 출발지점이 될 수 있다. #include #include //min using namespace std; int N; int..
https://www.acmicpc.net/problem/10819 10819번: 차이를 최대로 첫째 줄에 N (3 ≤ N ≤ 8)이 주어진다. 둘째 줄에는 배열 A에 들어있는 정수가 주어진다. 배열에 들어있는 정수는 -100보다 크거나 같고, 100보다 작거나 같다. www.acmicpc.net [풀이] N개의 정수로 이루어진 모든 순열을 식에 대입하여 그 결과값을 비교하여 최댓값을 구하였다. (Brute force) 수의 순서에 따라 결과값이 달라지므로 순열을 이용하였다. #include #include #include //max #include //abs using namespace std; int N; int A[9]; vectorv; int Max = -1; bool Select[9]; //식에..