Using Language : Java Using Tool : IntelliJ 프로그래머스 문제 소개 문제 설명 1937년 Collatz란 사람에 의해 제기된 이 추측은, 주어진 수가 1이 될때까지 다음 작업을 반복하면, 모든 수를 1로 만들 수 있다는 추측입니다. 작업은 다음과 같습니다. 1-1. 입력된 수가 짝수라면 2로 나눕니다. 1-2. 입력된 수가 홀수라면 3을 곱하고 1을 더합니다. 2. 결과로 나온 수에 같은 작업을 1이 될 때까지 반복합니다. 예를 들어, 입력된 수가 6이라면 6→3→10→5→16→8→4→2→1 이 되어 총 8번 만에 1이 됩니다. 위 작업을 몇 번이나 반복해야하는지 반환하는 함수, solution을 완성해 주세요. 단, 작업을 500번을 반복해도 1이 ..
Using Language : Java Using Tool : IntelliJ 프로그래머스 문제 소개 문제 설명 두 수를 입력받아 두 수의 최대공약수와 최소공배수를 반환하는 함수, solution을 완성해 보세요. 배열의 맨앞에 최대공약수, 그다음 최소공배수를 넣어 반환하면 됩니다. 예를 들어 두 수 3, 12의 최대공약수는 3, 최소공배수는 12이므로 solution(3, 12)는 [3, 12]를 반환해야 합니다. 제한 조건 두 수는 1이상 1000000이하의 자연수입니다. 예시 n m return 3 12 [3, 12] 2 5 [1, 10] 의사코드 java의 BitInteger 함수 사용해보기 최대공약수는 gcd를 이용해서 구하고, 최소공배수는 두 수를 곱한 값에서 최..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다. 제한 조건 arr은 길이 1 이상인 배열입니다. 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다. 예시 arr return [4,3,2,1] [4,3,2] [10] [-1] 의사코드 if문을 이용해서 arr배열의 값이 1개일 경우 return -1 최..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 임의의 정수 n에 대해, n이 어떤 정수 x의 제곱인지 아닌지 판단하려 합니다. n이 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요. 제한 조건 n은 1이상, 50000000000000 이하인 정수입니다. 예시 nreturn 121144 3-1 의사코드 double 형태의 변수를 선언하고 Math함수를 이용해서 n의 제곱근 저장 double형 변수를 int로 변형해서 int 변수에 넣어준다. int 변수와 double형 변수를 비교해서 값이 같으면 나머지가 없이 나누어 떨어지는 제곱근이다. 삼항 연산자를..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다. 제한 조건 n은 1이상 8000000000 이하인 자연수입니다. 예시 n return 118372 873211 의사코드 n의 길이를 구해준다 n의 길이만큼 String 배열을 만들어서 long형인 n을 한글자씩 넣어준다 내림차순하는 함수를 이용해서 String 배열을 내림차순 정렬을한다 String을 선언해서 내림차순한 배열을 순서대로 String에 넣어준다 스트링을 L..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n이 12345이면 [5,4,3,2,1]을 리턴합니다. 제한 조건 n은 10,000,000,000이하인 자연수입니다. 예시 n return 12345 [5,4,3,2,1] 의사코드 n의 길이를 구해서 for문 돌리기 n을 10으로 나누어서 나머지값 배열에 넣어주기 자릿수 구하기에서 쓴 방법과 동일하다! input 타입이 long 형이므로, 연산할때 int형으로 변형해서 해주어야한다! long형인걸 간과해서 왜 안되나 했다.. package level1; public class..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 자연수 N이 주어지면, N의 각 자릿수의 합을 구해서 return 하는 solution 함수를 만들어 주세요. 예를들어 N = 123이면 1 + 2 + 3 = 6을 return 하면 됩니다. 제한 조건 N의 범위 : 100,000,000 이하의 자연수 예시 N answer 123 6 987 24 의사코드 Int 값으로 받은 n을 String형으로 변형시켜서 String배열에 한글자씩 넣어주기 for문으로 String배열 길이만큼 돌려주기 String 배열에 들어있는 값을 Integer형으로 변환해서 answer에 넣어주기 위에처럼 생각하고 풀었는데 더 편한 코드가 보여서 코..
Using Language : Java Using Tool : Eclipse 프로그래머스 문제 소개 문제 설명 함수 solution은 정수 x와 자연수 n을 입력 받아, x부터 시작해 x씩 증가하는 숫자를 n개 지니는 리스트를 리턴해야 합니다. 다음 제한 조건을 보고, 조건을 만족하는 함수, solution을 완성해주세요. 제한 조건 x는 -10000000 이상, 10000000 이하인 정수입니다. n은 1000 이하인 자연수입니다. 예시 x nanswer 2 5 [2,4,6,8,10] 4 3 [4,8,12] -4 2 [-4, -8] 의사코드 answer 배열 0번째에 x값 넣어주기 for문으로 배열 1번째부터 n길이까지 돌려주기 배열의 인덱스 -1 번째에서 값 추..