백준(35)
-
2학기 4주차_알고리즘( 백준2577번 : 숫자의 개수 )
문제 세 개의 자연수 A, B, C가 주어질 때 A × B × C를 계산한 결과에 0부터 9까지 각각의 숫자가 몇 번씩 쓰였는지를 구하는 프로그램을 작성하시오. 예를 들어 A = 150, B = 266, C = 427 이라면 A × B × C = 150 × 266 × 427 = 17037300 이 되고, 계산한 결과 17037300 에는 0이 3번, 1이 1번, 3이 2번, 7이 2번 쓰였다. 입력 첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다. 출력 첫째 줄에는 A × B × C의 결과에 0 이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A × B × C의 결과에 1부터 9까지의 숫자가 각각..
2023.10.28 -
2학기 3주차_알고리즘( 백준11866번 : 요세푸스 문제 0 )
두번째 문제이다. 문제 ➡️문제 요세푸스 문제는 다음과 같다. 1번부터 N번까지 N명의 사람이 원을 이루면서 앉아있고, 양의 정수 K(≤ N)가 주어진다. 이제 순서대로 K번째 사람을 제거한다. 한 사람이 제거되면 남은 사람들로 이루어진 원을 따라 이 과정을 계속해 나간다. 이 과정은 N명의 사람이 모두 제거될 때까지 계속된다. 원에서 사람들이 제거되는 순서를 (N, K)-요세푸스 순열이라고 한다. 예를 들어 (7, 3)-요세푸스 순열은 이다. N과 K가 주어지면 (N, K)-요세푸스 순열을 구하는 프로그램을 작성하시오. ➡️입력 첫째 줄에 N과 K가 빈 칸을 사이에 두고 순서대로 주어진다. (1 ≤ K ≤ N ≤ 1,000) ➡️출력 예제와 같이 요세푸스 순열을 출력한다. 코드 (1차 시도) #defi..
2023.09.30 -
2학기 2주차_알고리즘( 백준19532번 : 수학은 비대면강의입니다. )
[ 문제 ] 그냥 수학문제로 풀면 잘 풀 수 있지만, 이걸 코드를 짜려는 어떤식으로 짜야할지.. 우선 ax+by = c 와 dx+ey = f가 같다고 두고 두 식을 빼서 x와 y의 값을 구해야 하고 출력이 되면 답이다. 어떤 식으로 짜야할까? 일단 for로 반복을 해야할 거 같고, if로 조건을 둬야할것같다. 예를 들어 for 이 999만큼 반복될 수 있다고 가정하고, if (a==d || d==e) 만약에 a와 d가 같거나 d와 e가 같을때 result 결과값은 ax+by-c= dx+ey-f 라고 하고 풀어볼까..? 음 아닌거 같다. 이렇게하면 코드는 안돌아갈 것 같다. 도움을 받아보자. #pragma warning(disable:4996) #include int main() { int x1, y1, ..
2023.09.24 -
2학기 2주차_알고리즘( 백준2164번 : 카드2 )
[ 문제 ] 2주차 첫번째 문제를 풀어보겠다. ➡️문제 N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다. 이제 다음과 같은 동작을 카드가 한 장 남을 때까지 반복하게 된다. 우선, 제일 위에 있는 카드를 바닥에 버린다. 그 다음, 제일 위에 있는 카드를 제일 아래에 있는 카드 밑으로 옮긴다. 예를 들어 N=4인 경우를 생각해 보자. 카드는 제일 위에서부터 1234 의 순서로 놓여있다. 1을 버리면 234가 남는다. 여기서 2를 제일 아래로 옮기면 342가 된다. 3을 버리면 42가 되고, 4를 밑으로 옮기면 24가 된다. 마지막으로 2를 버리고 나면, 남는 카드는 4가 된다. N이 주어졌을..
2023.09.24 -
2학기 1주차_알고리즘( 백준10773번 : 제로 )
[ 문제 ] ▶문제 나코더 기장 재민이는 동아리 회식을 준비하기 위해서 장부를 관리하는 중이다. 재현이는 재민이를 도와서 돈을 관리하는 중인데, 애석하게도 항상 정신없는 재현이는 돈을 실수로 잘못 부르는 사고를 치기 일쑤였다. 재현이는 잘못된 수를 부를 때마다 0을 외쳐서, 가장 최근에 재민이가 쓴 수를 지우게 시킨다. 재민이는 이렇게 모든 수를 받아 적은 후 그 수의 합을 알고 싶어 한다. 재민이를 도와주자! ▶입력 첫 번째 줄에 정수 K가 주어진다. (1 ≤ K ≤ 100,000) 이후 K개의 줄에 정수가 1개씩 주어진다. 정수는 0에서 1,000,000 사이의 값을 가지며, 정수가 "0" 일 경우에는 가장 최근에 쓴 수를 지우고, 아닐 경우 해당 수를 쓴다. 정수가 "0"일 경우에 지울 수 있는 수..
2023.09.17 -
2학기 1주차_알고리즘( 백준1978번 : 소수 찾기 )
[ 문제 ] ▶문제 주어진 수 N개 중에서 소수가 몇 개인지 찾아서 출력하는 프로그램을 작성하시오. ▶입력 첫 줄에 수의 개수 N이 주어진다. N은 100이하이다. 다음으로 N개의 수가 주어지는데 수는 1,000 이하의 자연수이다. ▶출력 주어진 수들 중 소수의 개수를 출력한다. [ 작성한 코드 ] #include int main(void) { int n; int num = 0; int count = 0; scanf("%d", &n); for (int i = 0; i < n; i++) { scanf("%d", &num); for (int k = 2; k
2023.09.17