Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 이미지가 포함된 게시글
- 알림생성모듈
- 포트번호
- Winston
- 부트캠프
- 토큰
- JSON Web Token
- element.style
- secret코드
- 레포지토리
- 스테이지어스
- 메뉴바 한번에
- 패스파라미터
- 메뉴바
- .env
- N+1
- 쿼리스트링
- JWT 쓰는 방법
- getComputedStyle
- route 53
- 게시글 이미지
- 네비게이션 한번에
- unnest
- 3계층구조
- 알림생성
- N+1문제
- 게시글 이미지 업로드
- JWT 쓰는이유
- 환경변수
- JWT
Archives
- Today
- Total
기주
[코테] 문제 12.암호 본문
2. 암호
1. “#*****#”를 일곱자리의 이진수로 바꿉니다. #은 이진수의 1로, *이진수의 0으로 변환합니다. 결과는 “1000001”로 변환됩니다.
2. 바뀐 2진수를 10진수화 합니다. “1000001”을 10진수화 하면 65가 됩니다.
3. 아스키 번호가 65문자로 변환합니다. 즉 아스크번호 65는 대문자 'A'입니다.
참고로 대문자들의 아스키 번호는 'A'는 65번, ‘B'는 66번, ’C'는 67번 등 차례대로 1씩 증가하여 ‘Z'는 90번입니다.
현수가 4개의 문자를 다음과 같이 신호로 보냈다면
#****###**#####**#####**##**
이 신호를 4개의 문자신호로 구분하면
#****## --> 'C'
#**#### --> 'O'
#**#### --> 'O'
#**##** --> 'L'
입력
첫 줄에는 보낸 문자의 개수(10을 넘지 안습니다)가 입력된다. 다음 줄에는 문자의 개수의 일곱 배 만큼의 #또는 * 신호가 입력됩니다.
현수는 항상 대문자로 해석할 수 있는 신호를 보낸다고 가정합니다.
출력
영희가 해석한 문자열을 출력합니다.
예시 입력 1
4
#****###**#####**#####**##**
예시 출력 1
COOL
Scanner sc = new Scanner(System.in);
int num = Integer.parseInt(sc.nextLine());
String str = sc.nextLine();
String answer = "";
for(int i=0; i<num; i++){
String s = str.substring(0,7).replace('#','1').replace('*','0');
str = str.substring(7); // substring을 이용해서 7번째~끝까지 자름
int n = Integer.parseInt(s,2); // parseInt를 통해 2진수로 변환
answer+=(char)n; // char은 원래 아스키코드 숫자형으로 처리되므로, 문자형으로 변환시켜 저장.
}
System.out.print(answer);
'알고리즘 > 코테' 카테고리의 다른 글
[코테] java 2-4 피보나치 수열 (0) | 2024.11.02 |
---|---|
[코테] java - 2-3 가위바위보 (0) | 2024.11.01 |
[코테] java - ArrayList 메서드 정리 (0) | 2024.10.30 |
[코테] java배열 메서드 정리 (0) | 2024.10.30 |
[코테] java-중복된 문자 제거하기 (0) | 2024.10.28 |