본문 바로가기

Algorithm75

자연수 뒤집어 배열로 만들기 · 문제 설명 자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n이 12345이면 [5,4,3,2,1]을 리턴합니다. · 제한 조건 n은 10,000,000,000이하인 자연수입니다. · 입출력 예 n return 12345 [5, 4, 3, 2, 1] · Thinking 1 1. n을 일단 String으로 변환해서 자릿값 알아내기 2. int배열 자릿값 만큼의 크기로 만들기 3. int[i] = charAt(length-i) 담기 · 완성 코드 class Solution { public int[] solution(long n) { String num = String.valueOf(n); int[] answer = new int[num.length()]; for (i.. 2019. 5. 31.
자릿수 더하기 · 문제 설명 자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요. 예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다. · 제한 사항 N의 범위 : 100,000,000 이하의 자연수 · 입출력 예 N answer 123 6 987 24 · 입출력 예 설명 입출력 예 #1 문제의 예시와 같습니다. 입출력 예 #2 9 + 8 + 7 = 24이므로 24를 return 하면 됩니다. · Thinking 1 String 으로 casting 후 charAt(i) 으로 각각 더하기 · 완성 코드 public class Solution { public int solution(int n) { String ch = Integer.toS.. 2019. 5. 31.
이상한 문자 만들기 · 문제 설명 문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요. · 제한 사항 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다. · 입출력 예 s return try hello world TrY HeLlO WoRlD · 입출력 예 설명 try hello world는 세 단어 try, hello, world로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 TrY, HeLlO, WoRlD입니다. 따라서 TrY HeLlO WoRlD 를 리.. 2019. 5. 31.
예산 · 문제 설명 S사에서는 각 부서에 필요한 물품을 지원해 주기 위해 부서별로 물품을 구매하는데 필요한 금액을 조사했습니다. 그러나, 전체 예산이 정해져 있기 때문에 모든 부서의 물품을 구매해 줄 수는 없습니다. 그래서 최대한 많은 부서의 물품을 구매해 줄 수 있도록 하려고 합니다. 물품을 구매해 줄 때는 각 부서가 신청한 금액만큼을 모두 지원해 줘야 합니다. 예를 들어 1,000원을 신청한 부서에는 정확히 1,000원을 지원해야 하며, 1,000원보다 적은 금액을 지원해 줄 수는 없습니다. 부서별로 신청한 금액이 들어있는 배열 d와 예산 budget이 매개변수로 주어질 때, 최대 몇 개의 부서에 물품을 지원해 줄 수 있는지 return 하도록 solution 함수를 완성해주세요. · 제한 사항 d는 부서.. 2019. 5. 31.
약수의 합 · 문제 설명 자연수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요. · 제한 사항 n은 0 이상 3000이하인 자연수입니다. · 입출력 예 n return 12 28 5 6 · 입출력 예 설명 입출력 예 #1 12의 약수는 1, 2, 3, 4, 6, 12입니다. 이를 모두 더하면 28입니다. 입출력 예 #2 5의 약수는 1, 5입니다. 이를 모두 더하면 6입니다. · Thinking 1 나머지가 0인 수 더하면 될듯 · 완성 코드 class Solution { public int solution(int n) { int answer = 0; for (int i = 1; i 2019. 5. 31.
시저 암호 · 문제 설명 어떤 문장의 각 알파벳을 일정한 거리만큼 밀어서 다른 알파벳으로 바꾸는 암호화 방식을 시저 암호라고 합니다. 예를 들어 AB는 1만큼 밀면 BC가 되고, 3만큼 밀면 DE가 됩니다. z는 1만큼 밀면 a가 됩니다. 문자열 s와 거리 n을 입력받아 s를 n만큼 민 암호문을 만드는 함수, solution을 완성해 보세요. · 제한 조건 s는 알파벳 소문자, 대문자, 공백으로만 이루어져 있습니다. s의 길이는 8000이하입니다. n은 1 이상, 25이하인 자연수입니다. · 입출력 예 s n result AB 1 BC z 1 a a B z 4 e F d · Thinking 1 1. 공백을 제거한 string값을 일단 만들고 (공백에 해당하는 index는 저장) 2. z를 밀면 다시 a로 돌아오게끔.. 2019. 5. 31.
수박수박수박수박수박수? · 문제 설명 길이가 n이고, 수박수박수박수....와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 수박수박을 리턴하고 3이라면 수박수를 리턴하면 됩니다. · 제한 조건 n은 길이 10,000이하인 자연수입니다. · 입출력 예 n return 3 수박수 4 수박수박 · 완성 코드 class Solution { public String solution(int n) { String answer = ""; for (int i = 0; i < n; i++) { if (i % 2 == 0) { answer+= "수"; } else { answer+= "박"; } } return answer; } } · 다른 사람의 풀이 class Solution { public.. 2019. 5. 31.
소수 찾기 · 문제 설명 1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요. 소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다. (1은 소수가 아닙니다.) · 제한 조건 n은 2이상 1000000이하의 자연수입니다. · 입출력 예 n result 10 4 5 3 · 입출력 예 설명 입출력 예 #1 1부터 10 사이의 소수는 [2,3,5,7] 4개가 존재하므로 4를 반환 입출력 예 #2 1부터 5 사이의 소수는 [2,3,5] 3개가 존재하므로 3를 반환 · Thinking 1 소수 : 1과 자기자신으로만 나누어 떨어지는 수 a % b == 0 일때, b가 a가 아닌경우 --; class Solution { public int solution(int n) { in.. 2019. 5. 31.
서울에서 김서방 찾기 · 문제 설명 String형 배열 seoul의 element중 Kim의 위치 x를 찾아, 김서방은 x에 있다는 String을 반환하는 함수, solution을 완성하세요. seoul에 Kim은 오직 한 번만 나타나며 잘못된 값이 입력되는 경우는 없습니다. · 제한 설명 seoul은 길이 1 이상, 1000 이하인 배열입니다. seoul의 원소는 길이 1 이상, 20 이하인 문자열입니다. Kim은 반드시 seoul 안에 포함되어 있습니다. · 입출력 예 seoul return [Jane, Kim] 김서방은 1에 있다 · Thinking 1 Kim이 몇번째 인덱스인지만 알면 된다 · 완성 코드 class Solution { public String solution(String[] seoul) { String.. 2019. 5. 31.