[Java] 프로그래머스 암호해독
2023. 2. 10. 21:17ㆍ알고리즘
728x90
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열 cipher를 주고받습니다.
- 그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ cipher의 길이 ≤ 1,000
- 1 ≤ code ≤ cipher의 길이
- cipher는 소문자와 공백으로만 구성되어 있습니다.
- 공백도 하나의 문자로 취급합니다.
입출력 예
입출력 예 설명
입출력 예 #1
- "dfjardstddetckdaccccdegk" 의 4번째, 8번째, 12번째, 16번째, 20번째, 24번째 글자를 합친 "attack"을 return합니다.
입출력 예 #2
- "pfqallllabwaoclk" 의 2번째, 4번째, 6번째, 8번째, 10번째, 12번째, 14번째, 16번째 글자를 합친 "fallback"을 return합니다.
코드 설명
import java.util.Scanner;
public class Solution {
public String solution(String cipher, int code) {
String answer = "";
int num = code; // num에 code를 넣어주고
for (int i = 0; i < cipher.length() / code; i++) { // 0 ~ cipher의 길이 / code 전 만큼
answer += cipher.charAt(num - 1); // answer에 cipher(num - 1)문자를 넣어줌(우리는 문자열을 0부터 시작하지만 문제는 1부터 시작함)
num += code; // for문 돌때마다 num += code해줌 (배수)
}
return answer;
}
public static void main(String[] args) {
Solution T = new Solution();
Scanner sc = new Scanner(System.in);
String cipher = sc.next();
int code = sc.nextInt();
System.out.println(T.solution(cipher,code));
sc.close();
}
}
728x90
'알고리즘' 카테고리의 다른 글
[Java] 프로그래머스 대문자와 소문자 (0) | 2023.02.10 |
---|---|
[Java] 프로그래머스 영어가 싫어요 (0) | 2023.02.10 |
[Java] 프로그래머스 인덱스 바꾸기 (0) | 2023.02.10 |
[Java] 프로그래머스 한 번만 등장한 문자 (0) | 2023.02.10 |
[Java] 프로그래머스 크레인 인형뽑기 게임 (0) | 2023.02.10 |