동기의 이것저것
article thumbnail
[프로그래머스] 폰켓몬(JAVA) / Level1 / 해시
▸프로그래머스/Lv1 2023. 4. 5. 23:59

문제 설명 당신은 폰켓몬을 잡기 위한 오랜 여행 끝에, 홍 박사님의 연구실에 도착했습니다. 홍 박사님은 당신에게 자신의 연구실에 있는 총 N 마리의 폰켓몬 중에서 N/2마리를 가져가도 좋다고 했습니다.홍 박사님 연구실의 폰켓몬은 종류에 따라 번호를 붙여 구분합니다. 따라서 같은 종류의 폰켓몬은 같은 번호를 가지고 있습니다. 예를 들어 연구실에 총 4마리의 폰켓몬이 있고, 각 폰켓몬의 종류 번호가 [3번, 1번, 2번, 3번]이라면 이는 3번 폰켓몬 두 마리, 1번 폰켓몬 한 마리, 2번 폰켓몬 한 마리가 있음을 나타냅니다. 이때, 4마리의 폰켓몬 중 2마리를 고르는 방법은 다음과 같이 6가지가 있습니다. 1. 첫 번째(3번), 두 번째(1번) 폰켓몬을 선택 2. 첫 번째(3번), 세 번째(2번) 폰켓몬을..

article thumbnail
프로그래머스 Lv0_순서쌍의 개수
▸프로그래머스/Lv0 2023. 4. 1. 22:56

문제 설명 순서쌍이란 두 개의 숫자를 순서를 정하여 짝지어 나타낸 쌍으로 (a, b)로 표기합니다. 자연수 n이 매개변수로 주어질 때 두 숫자의 곱이 n인 자연수 순서쌍의 개수를 return하도록 solution 함수를 완성해주세요. 제한 사항 1 ≤ n ≤ 1,000,000 입출력 예 n result 20 6 100 9 "n이 20 이므로 곱이 20인 순서쌍은 (1, 20), (2, 10), (4, 5), (5, 4), (10, 2), (20, 1) 이므로 6을 return합니다. n이 100 이므로 곱이 100인 순서쌍은 (1, 100), (2, 50), (4, 25), (5, 20), (10, 10), (20, 5), (25, 4), (50, 2), (100, 1) 이므로 9를 return합니다. ..

article thumbnail
프로그래머스 Lv0_문자 반복 출력하기
▸프로그래머스/Lv0 2023. 4. 1. 22:55

문제 설명 문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string에 들어있는 각 문자를 n만큼 반복한 문자열을 return 하도록 solution 함수를 완성해보세요. 제한 사항 2 ≤ my_string 길이 ≤ 5 2 ≤ n ≤ 10 "my_string"은 영어 대소문자로 이루어져 있습니다. 입출력 예 my_string n result "hello" 3 "hhheeellllllooo" "hello"의 각 문자를 세 번씩 반복한 "hhheeellllllooo"를 return 합니다. Solution.java class Solution { public String solution(String my_string, int n) { String answer = ""; for(int i =..

article thumbnail
프로그래머스 Lv0_짝수의 합
▸프로그래머스/Lv0 2023. 4. 1. 22:48

문제 설명 정수 n이 주어질 때, n이하의 짝수를 모두 더한 값을 return 하도록 solution 함수를 작성해주세요. 제한 사항 0 < n ≤ 1000 입출력 예 n result 10 30 4 6 n이 10이므로 2 + 4 + 6 + 8 + 10 = 30을 return 합니다. n이 4이므로 2 + 4 = 6을 return 합니다. Solution.java class Solution { public int solution(int n) { int answer = 0; if(0

article thumbnail
[프로그래머스] 디스크 컨트롤러(JAVA) / Level3 / 힙, 우선순위 큐
▸프로그래머스/Lv3 2023. 3. 27. 23:01

문제 설명 하드디스크는 한 번에 하나의 작업만 수행할 수 있습니다. 디스크 컨트롤러를 구현하는 방법은 여러 가지가 있습니다. 가장 일반적인 방법은 요청이 들어온 순서대로 처리하는 것입니다. 예를 들어 - 0ms 시점에 3ms가 소요되는 A작업 요청 - 1ms 시점에 9ms가 소요되는 B작업 요청 - 2ms 시점에 6ms가 소요되는 C작업 요청 한 번에 하나의 요청만을 수행할 수 있기 때문에 각각의 작업을 요청받은 순서대로 처리하면 다음과 같이 처리 됩니다. 이 때 각 작업의 요청부터 종료까지 걸린 시간의 평균은 10ms(= (3 + 11 + 16) / 3)가 됩니다. 하지만 A → C → B 순서대로 처리하면 이렇게 A → C → B의 순서로 처리하면 각 작업의 요청부터 종료까지 걸린 시간의 평균은 9m..

article thumbnail
프로그래머스 Lv0_양꼬치
▸프로그래머스/Lv0 2023. 3. 26. 18:40

문제 설명 머쓱이네 양꼬치 가게는 10인분을 먹으면 음료수 하나를 서비스로 줍니다. 양꼬치는 1인분에 12,000원, 음료수는 2,000원입니다. 정수 n과 k가 매개변수로 주어졌을 때, 양꼬치 n인분과 음료수 k개를 먹었다면 총얼마를 지불해야 하는지 return 하도록 solution 함수를 완성해보세요. 제한 사항 0 < n < 1,000 n / 10 ≤ k < 1,000 서비스로 받은 음료수는 모두 마십니다 입출력 예 n k result 10 3 124,000 64 6 768,000 10인분을 시켜 서비스로 음료수를 하나 받아 총 10 12000 + 3 2000 - 1 * 2000 = 124,000원입니다. 64인분을 시켜 서비스로 음료수를 6개 받아 총 64 12000 + 6 2000 - 6 *..

article thumbnail
프로그래머스 Lv0_각도기
▸프로그래머스/Lv0 2023. 3. 26. 18:38

문제 설명 각에서 0도 초과 90도 미만은 예각, 90도는 직각, 90도 초과 180도 미만은 둔각 180도는 평각으로 분류합니다. 각 angle이 매개변수로 주어질 때 예각일 때 1, 직각일 때 2, 둔각일 때 3, 평각일 때 4를 return하도록 solution 함수를 완성해주세요. 예각 : 0 < angle < 90 직각 : angle = 90 둔각 : 90 < angle < 180 평각 : angle = 180 제한 사항 0 < angle ≤ 180 angle은 정수입니다. 입출력 예 angle result 70 1 91 3 angle이 70이므로 예각입니다. 따라서 1을 return합니다. angle이 91이므로 둔각입니다. 따라서 3을 return합니다. Solution.java class ..

article thumbnail
프로그래머스 Lv0_두 수의 나눗셈
▸프로그래머스/Lv0 2023. 3. 26. 18:36

문제 설명 정수 num1과 num2가 매개변수로 주어질 때, num1을 num2로 나눈 값에 1,000을 곱한 후 정수 부분을 return 하도록 soltuion 함수를 완성해주세요. 제한 사항 0 < num1 ≤ 100 0 < num2 ≤ 100 입출력 예 num1 num2 result 3 2 1500 7 3 2333 num1이 3, num2가 2이므로 3 / 2 = 1.5에 1,000을 곱하면 1500이 됩니다. num1이 7, num2가 3이므로 7 / 3 = 2.33333...에 1,000을 곱하면 2333.3333.... 이 되며, 정수 부분은 2333입니다. Solution.java class Solution { public int solution(int num1, int num2) { int..

article thumbnail
프로그래머스 Lv0_나이 출력
▸프로그래머스/Lv0 2023. 3. 26. 18:35

문제 설명 머쓱이는 40살인 선생님이 몇 년도에 태어났는지 궁금해졌습니다. 나이 age가 주어질 때, 2022년을 기준 출생 연도를 return 하는 solution 함수를 완성해주세요. 제한 사항 0 < age ≤ 120 나이는 태어난 연도에 1살이며 1년마다 1씩 증가합니다. 입출력 예 age result 40 1983 23 2000 2022년 기준 40살이므로 1983년생입니다. 2022년 기준 23살이므로 2000년생입니다. Solution.java class Solution { public int solution(int age) { int answer = 0; if(0

반응형