프로그래머스 코딩테스트 [Java]
3진법 뒤집기
💫문제 설명💫
자연수 n이 매개변수로 주어집니다.
n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.
💫제한사항💫
n은 1 이상 100,000,000 이하인 자연수입니다.
💫입출력 ex💫
n | result |
---|---|
45 | 7 |
125 | 229 |
문제풀이
class Solution {
public int solution(int n) {
int answer = 0;
String str = "";
while (n != 0) {
str += n % 3;
n /= 3;
}
answer = Integer.parseInt(str, 3);
return answer;
}
}
예산
💫문제 설명💫
S사에서는 각 부서에 필요한 물품을 지원해 주기 위해 부서별로 물품을 구매하는데 필요한 금액을 조사했습니다.
그러나, 전체 예산이 정해져 있기 때문에 모든 부서의 물품을 구매해 줄 수는 없습니다.
그래서 최대한 많은 부서의 물품을 구매해 줄 수 있도록 하려고 합니다.
물품을 구매해 줄 때는 각 부서가 신청한 금액만큼을 모두 지원해 줘야 합니다.
예를 들어 1,000원을 신청한 부서에는 정확히 1,000원을 지원해야 하며, 1,000원보다 적은 금액을 지원해 줄 수는 없습니다.
부서별로 신청한 금액이 들어있는 배열 d와 예산 budget이 매개변수로 주어질 때,
최대 몇 개의 부서에 물품을 지원할 수 있는지 return 하도록 solution 함수를 완성해주세요.
💫제한사항💫
d는 부서별로 신청한 금액이 들어있는 배열이며, 길이(전체 부서의 개수)는 1 이상 100 이하입니다.
d의 각 원소는 부서별로 신청한 금액을 나타내며, 부서별 신청 금액은 1 이상 100,000 이하의 자연수입니다.
budget은 예산을 나타내며, 1 이상 10,000,000 이하의 자연수입니다.
💫입출력 ex💫
d | budget | result |
---|---|---|
[1,3,2,5,4] | 9 | 3 |
[2,2,3,3] | 10 | 4 |
문제풀이
import java.util.*;
class Solution {
public int solution(int[] d, int budget) {
int answer = 0;
Arrays.sort(d);
for(int i=0; i < d.length; i++) {
budget -= d[i];
if(budget < 0) {
break;
}
answer++;
}
return answer;
}
}
이상한 문자 만들기
💫문제 설명💫
문자열 s는 한 개 이상의 단어로 구성되어 있습니다.
각 단어는 하나 이상의 공백문자로 구분되어 있습니다.
각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
💫제한사항💫
문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
💫입출력 ex💫
s | return |
---|---|
“try hello world” | “TrY HeLlO WoRlD” |
문제풀이
class Solution {
public String solution(String s) {
String answer = "";
String[] list = s.split("");
int cnt = 0;
for(String str : list) {
cnt = str.contains(" ") ? 0 : cnt + 1;
answer += (cnt%2 == 0) ? str.toLowerCase() : str.toUpperCase();
}
return answer;
}
}
크기가 작은 부분 문자열
💫문제 설명💫
숫자로 이루어진 문자열 t와 p가 주어질 때,
t에서 p와 길이가 같은 부분문자열 중에서, 이 부분문자열이 나타내는 수가 p가 나타내는 수보다 작거나 같은 것이 나오는 횟수를 return하는 함수 solution을 완성하세요.
예를 들어, t="3141592"이고 p="271" 인 경우,
t의 길이가 3인 부분 문자열은 314, 141, 415, 159, 592입니다.
이 문자열이 나타내는 수 중 271보다 작거나 같은 수는 141, 159 2개 입니다.
💫제한사항💫
1 ≤ p의 길이 ≤ 18
p의 길이 ≤ t의 길이 ≤ 10,000
t와 p는 숫자로만 이루어진 문자열이며, 0으로 시작하지 않습니다.
💫입출력 ex💫
t | p | return |
---|---|---|
“3141592” | “271” | 2 |
“500220839878” | “7” | 8 |
“10203” | “15” | 3 |
문제풀이
class Solution {
public int solution(String t, String p) {
int answer = 0;
for(int i=0; i<=t.length()-p.length(); i++){
String str = t.substring(i,i+p.length());
if(Long.parseLong(str) <= Long.parseLong(p)){
answer++;
}
}
return answer;
}
}
삼총사
💫문제 설명💫
한국중학교에 다니는 학생들은 각자 정수 번호를 갖고 있습니다.
이 학교 학생 3명의 정수 번호를 더했을 때 0이 되면 3명의 학생은 삼총사라고 합니다.
예를 들어, 5명의 학생이 있고, 각각의 정수 번호가 순서대로 -2, 3, 0, 2, -5일 때, 첫 번째, 세 번째, 네 번째 학생의 정수 번호를 더하면 0이므로 세 학생은 삼총사입니다.
또한, 두 번째, 네 번째, 다섯 번째 학생의 정수 번호를 더해도 0이므로 세 학생도 삼총사입니다.
따라서 이 경우 한국중학교에서는 두 가지 방법으로 삼총사를 만들 수 있습니다.
한국중학교 학생들의 번호를 나타내는 정수 배열 number가 매개변수로 주어질 때,
학생들 중 삼총사를 만들 수 있는 방법의 수를 return 하도록 solution 함수를 완성하세요.
💫제한사항💫
3 ≤ number의 길이 ≤ 13
-1,000 ≤ number의 각 원소 ≤ 1,000
서로 다른 학생의 정수 번호가 같을 수 있습니다.
💫입출력 ex💫
number | return |
---|---|
[-2, 3, 0, 2, -5] | 2 |
[-3, -2, -1, 0, 1, 2, 3] | 5 |
[-1, 1, -1, 1] | 0 |
문제풀이
class Solution {
public int solution(int[] number) {
int answer = 0;
for(int i = 0; i < number.length; i++) {
for(int j = i + 1; j < number.length; j++) {
for(int k = j + 1; k < number.length; k++) {
if(number[i] + number[j] + number[k] == 0) {
answer++;
}
}
}
}
return answer;
}
}
Leave a comment