-
자바 알고리즘 - 두 수의 연산값 비교하기algorithm 2023. 8. 23. 12:23
문제 설명 연산 ⊕는 두 정수에 대한 연산으로 두 정수를 붙여서 쓴 값을 반환합니다. 예를 들면 다음과 같습니다. 12 ⊕ 3 = 123 3 ⊕ 12 = 312 양의 정수 a와 b가 주어졌을 때, a ⊕ b와 2 * a * b 중 더 큰 값을 return하는 solution 함수를 완성해 주세요. 단, a ⊕ b와 2 * a * b가 같으면 a ⊕ b를 return 합니다. 제한 사항 1 ≤ a, b =(2*a*b)?val:(2*a*b); } } a와 b를 이은 문자열을 Integer.parseInt를 통해 형변환하여 val에 저장한다. 그리고 삼항 연산자를 통해 val과 2*a*b를 비교하여 val이 크거나 같다면 val을 리턴하고 작다면 2*a*b 값을 리턴시킨다.
-
자바 알고리즘 - 더 크게 합치기algorithm 2023. 8. 23. 11:55
문제 설명 연산 ⊕는 두 정수에 대한 연산으로 두 정수를 붙여서 쓴 값을 반환합니다. 예를 들면 다음과 같습니다. 12 ⊕ 3 = 123 3 ⊕ 12 = 312 양의 정수 a와 b가 주어졌을 때, a ⊕ b와 b ⊕ a 중 더 큰 값을 return 하는 solution 함수를 완성해 주세요. 단, a ⊕ b와 b ⊕ a가 같다면 a ⊕ b를 return 합니다. 제한 사항 1 ≤ a, b val2 ? val1 : val2; // return answer; } } int를 String으로 형변환해주는 Integer.toString을 이용해서 a와 b를 연결하고 연결된 문자열을 Integer.parseInt를 이용해서 문자열을 숫자로 형변환하여 val1에 담는다. 똑같이 b와 a를 연결하여 val2 에 담고..
-
자바 알고리즘 - 문자열 곱하기algorithm 2023. 8. 23. 11:37
문제 설명 문자열 my_string과 정수 k가 주어질 때, my_string을 k번 반복한 문자열을 return 하는 solution 함수를 작성해 주세요. 제한 사항 1 ≤ my_string의 길이 ≤ 100 my_string은 영소문자로만 이루어져 있습니다. 1 ≤ k ≤ 100 my_string k result "string" 3 "stringstringstring" "love" 10 "lovelovelovelovelovelovelovelovelovelove" 답안 class Solution { public String solution(String my_string, int k) { String answer = ""; for(int i=0; i
-
자바 알고리즘 - 문자 리스트를 문자열로 변환하기algorithm 2023. 8. 23. 11:15
문제 설명 문자들이 담겨있는 배열 arr가 주어집니다. arr의 원소들을 순서대로 이어 붙인 문자열을 return 하는 solution함수를 작성해 주세요. 제한사항 1 ≤ arr의 길이 ≤ 200 arr의 원소는 전부 알파벳 소문자로 이루어진 길이가 1인 문자열입니다. 입출력 예 arr result ["a","b","c"] "abc" 답안 class Solution { public String solution(String[] arr) { String answer = ""; for(String st : arr) { answer += st; } return answer; } } 향상된 for문을 이용하여 배열 arr의 원소 하나씩 answer에 더해서 return하는 방식. 다른 답안 class Solut..
-
자바 알고리즘 - 문자열 섞기algorithm 2023. 8. 23. 11:00
문제 설명 길이가 같은 두 문자열 str1과 str2가 주어집니다. 두 문자열의 각 문자가 앞에서부터 서로 번갈아가면서 한 번씩 등장하는 문자열을 만들어 return 하는 solution 함수를 완성해 주세요. 제한사항 1 ≤ str1의 길이 = str2의 길이 ≤ 10 str1과 str2는 알파벳 소문자로 이루어진 문자열입니다. 답안 class Solution { public String solution(String str1, String str2) { String answer = ""; for(int i=0; i
-
자바 알고리즘 - 문자열 겹쳐쓰기algorithm 2023. 8. 22. 21:09
문제 설명 문자열 my_string, overwrite_string과 정수 s가 주어집니다. 문자열 my_string의 인덱스 s부터 overwrite_string의 길이만큼을 문자열 overwrite_string으로 바꾼 문자열을 return 하는 solution 함수를 작성해 주세요. 제한 사항 my_string와 overwrite_string은 숫자와 알파벳으로 이루어져 있습니다. 1 ≤ overwrite_string의 길이 ≤ my_string의 길이 ≤ 1,000 0 ≤ s ≤ my_string의 길이 - overwrite_string의 길이 입출력 예 설명 예제 1번의 my_string에서 인덱스 2부터 overwrite_string의 길이만큼에 해당하는 부분은 "11oWor1"이고 이를 "l..
-
자바 알고리즘 - 홀짝 구분하기algorithm 2023. 8. 22. 19:26
문제 설명 자연수 n이 입력으로 주어졌을 때 만약 n이 짝수이면 "n is even"을, 홀수이면 "n is odd"를 출력하는 코드를 작성해 보세요. 제한사항 1 ≤ n ≤ 1,000 답안 import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); System.out.print(n + " is " + (n%2==0? "even":"odd")); } } 원래는 if문을 통해서 분기처리 했는데 삼항 연산자로 처리한 코드가 있어서 이걸로 다시 제출했다. 변수 n과 문자열 is 출력까지는 동일하기 때문에..
-
자바 알고리즘 - 문자열 돌리기algorithm 2023. 8. 22. 19:00
문제 설명 문자열 str이 주어집니다. 문자열을 시계방향으로 90도 돌려서 아래 입출력 예와 같이 출력하는 코드를 작성해 보세요. 제한 사항 1 ≤ str의 길이 ≤ 10 입출력 예시 #입력 abcde #출력 a b c d e 답안 import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String a = sc.next(); for(int i=0; i