백준 문제
-
백준 17608(막대기) c++백준 문제 2021. 9. 14. 23:09
문제 17608번: 막대기 아래 그림처럼 높이만 다르고 (같은 높이의 막대기가 있을 수 있음) 모양이 같은 막대기를 일렬로 세운 후, 왼쪽부터 차례로 번호를 붙인다. 각 막대기의 높이는 그림에서 보인 것처럼 순서대로 www.acmicpc.net 왼쪽부터 길이가 다른 막대를 세워두고. 막대들을 오른쪽에서 봤을때, 보이는 막대의 개수를 세는 문제입니다. 코드를 보겠습니다. int n; cin >> n; stacks; for (int i = 0; i > a; s.push(a); } 먼저 막대의 개수 n을 입력받습니다. 막대 길이를 저장할 공간으로 stack을 선택했는데 막대가 왼쪽부터 오른쪽으로 세우므로 stack을 이용해 맨 아래부분(맨 왼쪽) 부터 맨 윗부분(맨 ..
-
백준 2437(저울) c++백준 문제 2021. 9. 11. 17:23
문제 2437번: 저울 하나의 양팔 저울을 이용하여 물건의 무게를 측정하려고 한다. 이 저울의 양 팔의 끝에는 물건이나 추를 올려놓는 접시가 달려 있고, 양팔의 길이는 같다. 또한, 저울의 한쪽에는 저울추들만 놓 www.acmicpc.net 저울추가 주어지면 저울추로 잴 수 없는 가장 작은 수를 출력하면 됩니다. 단순히 문제만 보면 쉬워 보이지만 마땅히 생각이안나서 구글의 힘을 빌렸던 문제 입니다. 코드를 살펴보겠습니다. int n; cin >> n; vectorv(n); for (int i = 0; i > v[i]; } sort(v.begin(), v.end()); 먼저 저울이 개수인 n을 입력바고 n만큼 저울의 무게를 입력받아 벡터 v에 저장합니다. 그다음 오름차순으로 ..
-
백준 1448(삼각형 만들기) c++백준 문제 2021. 9. 11. 15:43
문제 1448번: 삼각형 만들기 첫째 줄에 빨대의 개수 N이 주어진다. N은 3보다 크거나 같고, 1,000,000보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에 빨대의 길이가 한 줄에 하나씩 주어진다. 빨대의 길이는 1,000,000보다 www.acmicpc.net 숫자를 입력받아 삼각형을 만들 수 있으면 그중 가장큰 삼각형 세변의 길이를 출력하고 삼각형을 만들 수 없으면 -1을 출력하는 문제입니다. 삼각형이 이루어질 수 있는 조건은 세변중 가장큰변이 나머지 두변의 합보다 작으면 가능합니다. 코드를 보겠습니다. int n; cin >> n; vectorv(n); for (int i = 0; i > v[i]; } 먼저 변의 개수를 받아줄 n을 입력받고 벡터v에 넣어줍..
-
백준 1377(버블 소트) c++백준 문제 2021. 9. 11. 00:25
문제 1377번: 버블 소트 첫째 줄에 N이 주어진다. N은 500,000보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에 A[1]부터 A[N]까지 하나씩 주어진다. A에 들어있는 수는 1,000,000보다 작거나 같은 자연수 또는 0이다. www.acmicpc.net 간단히 버블소트가 몇단계 만에 완성되는지 출력하는 문제입니다. 버블 소트는 한단계 실행 할때마다 배열안의 가장큰수가 맨뒤로 갑니다. 하지만 단순히 문제안에 있는 코드를 배껴서 제출하면 시간초과가 납니다. 버블소트의 시간복잡도는 O(N^2)인데 N이 최대 500만 까지 가능하므로 500만 * 500만 이면 시간이 너무 많이 듭니다. 굳이 정렬을 진행하지 않고 몇단계 만에 정렬이 되는지를 구하는것이 관건입니다. 코드를 보겠습니다. int..
-
백준 11582(치킨 TOP N) C언어백준 문제 2021. 9. 10. 01:32
문제 11582번: 치킨 TOP N 인하대 주변 치킨칩의 맛의 정도를 측정해 수치화하는 동아리 C.T.P(Chicken Tastes Perfect)의 회장 민호는 치킨집의 맛의 수치를 감소하지 않는 순으로 정렬을 하고 싶었다. 하지만 치킨집이 너무 많 www.acmicpc.net 간단한 머지소트 응용문제입니다. 그러다가 중간에 조건이 주어지고 그 조건에 들어가면 머지 소트를 멈추고 그대로 출력하는 문제입니다. 코드를 보겠습니다. int arr[1048577]; int tmp[1048577]; int n; int k; int main(){ scanf("%d",&n); for(int i=0;in/k) return; int idx1, idx2, idx3; idx1= idx3 = l; idx2 = m + 1; ..
-
백준 10610(30) c++백준 문제 2021. 9. 9. 20:19
문제 10610번: 30 어느 날, 미르코는 우연히 길거리에서 양수 N을 보았다. 미르코는 30이란 수를 존경하기 때문에, 그는 길거리에서 찾은 수에 포함된 숫자들을 섞어 30의 배수가 되는 가장 큰 수를 만들고 싶어한 www.acmicpc.net 입력받은 숫자가 자리수를 계속 옮기면서 30의 배수가 되면 그 수를 출력하고, 30의 배수가 아니면 -1을 출력하는 문제입니다. 처음에는 아무생각없이 입력받는 수를 int형으로 담으려다가 말이 안되서 문제를 다시 읽었습니다. 알고보니 숫자가 10^5가 아니가 숫자의 개수가 10^5개 입니다. 엄청나게 큰수이므로 가장 큰 자료형을 써도 오버플로우가 날것입니다. 따라서 문자열로 받고 나중에 숫자로 변환해주는 방식을 취해줄것입니다. 두번째 관건은 그 엄청난 수를 계..
-
백준 2346(풍선 터뜨리기) c++백준 문제 2021. 9. 6. 19:27
문제 2346번: 풍선 터뜨리기 1번부터 N번까지 N개의 풍선이 원형으로 놓여 있고. i번 풍선의 오른쪽에는 i+1번 풍선이 있고, 왼쪽에는 i-1번 풍선이 있다. 단, 1번 풍선의 왼쪽에 N번 풍선이 있고, N번 풍선의 오른쪽에 1번 풍선 www.acmicpc.net 전에 풀었던 요세푸스 문제에서 응용한 문제 입니다. 요세푸는 문제는 오직 한방향으로만 원형으로 이동하지만 이 문제는 양쪽 방향으로 다 이동할 수 있습니다. 따라서 양쪽 원소에 접근할 수 있는 덱(deque) 자료구조를 이용하였습니다. int n; cin >> n; dequed; for (int i = 0; i > k; d.push_back({ i + 1,k }); } 풍선의 개수를 변수 n을 통해..
-
백준 9093번(단어 뒤집기) c++백준 문제 2021. 9. 6. 01:29
문제 9093번: 단어 뒤집기 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 문장이 하나 주어진다. 단어의 길이는 최대 20, 문장의 길이는 최대 1000이다. 단어와 단어 사이에는 www.acmicpc.net 문장을 받아서 공백을 기준으로 뒤집어주면 됩니다. int T; cin>>T; cin.ignore(); 먼저 테이스케이스 T를 입력받습니다. 여기서 cin.ignore() 함수를 사용했는데 버퍼를 비워주는 역할을 합니다. 왜 여기서 버퍼가 제대로 안비워졌는지는 정확히는 모르겠습니다만 계속 버퍼가 안비워져서 cin.ignore()를 사용했습니다. 버퍼에 관한건 추가적으로 다시 조사하겠습니다. while (T--) { string st; getline(c..