inflearn logo
강의

講義

知識共有

Javaアルゴリズムの問​​題解説:コーディングテストに備えて

8. パリンドローム(replaceAll正規表現利用)

암호

121

없어요ㅎ

投稿した質問数 9

0

package Algorithm;
import java.util.*;

public class 암호 {
    public String solution(int n ,String s) {

        String answer = "";
        for(int i=0; i<n; i++){
            s = s.substring(0,7).replace('#','1').replace('*','0');
            int num = Integer.parseInt(s,2);  // 2 진수로 들어온 것을 10진수로 변경하는 방법  문자열 -> 숫자
            answer += (char)num;
            s=s.substring(7);  // 끝까지 나오기!
// substring (인덱스 해당 , 인덱스 해당 안됨)
        }

        return answer;
    }

    public static void main(String[] args) {

        암호 t = new 암호();
        Scanner kb = new Scanner(System.in);
        int n = kb.nextInt();
        String str = kb.next();
        System.out.println(t.solution(n, str));

    }
}

혹시 이렇게 풀면 왜 틀리는 건가요...? 감사합니다!

 

Exception in thread "main" java.util.InputMismatchException

at java.base/java.util.Scanner.throwFor(Scanner.java:939)

at java.base/java.util.Scanner.next(Scanner.java:1594)

at java.base/java.util.Scanner.nextInt(Scanner.java:2258)

at java.base/java.util.Scanner.nextInt(Scanner.java:2212)

at Algorithm.암호.main(암호.java:23)

 

java 코딩-테스트

回答 2

0

없어요ㅎ

s = s.substring(0,7).replace('#','1').replace('*','0');

여기부분은 상관없나요?

0

codingcamp

안녕하세요^^

그 부분에서 s를 변경하면 안됩니다.

아래와 같이 임시 변수에 저장해야 합니다.

String tmp = s.substring(0,7).replace('#','1').replace('*','0');

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

서윤정님이 작성하신 코드가 런타임 에러를 발생시키는 이유는 nextInt()nextLine()의 사용 방식 때문입니다. nextInt()는 입력을 받지만 줄바꿈 문자를 버퍼에 남겨두고, 그 뒤의 nextLine() 메서드는 줄바꿈 문자를 바로 읽어버리기 때문에 빈 문자열을 반환하게 됩니다.

이 문제를 해결하려면 nextInt() 후에 nextLine()을 한 번 더 호출하여 남아 있는 줄바꿈 문자를 제거해주시면 됩니다.

아래와 같이 수정해 보세요:

package Algorithm;
import java.util.*;

public class 암호 {
    public String solution(int n, String s) {
        String answer = "";
        for (int i = 0; i < n; i++) {
            String sub = s.substring(0, 7).replace('#', '1').replace('*', '0');
            int num = Integer.parseInt(sub, 2);  // 2진수로 들어온 것을 10진수로 변경하는 방법
            answer += (char) num;
            s = s.substring(7);  // 끝까지 나오기!
        }
        return answer;
    }

    public static void main(String[] args) {
        암호 t = new 암호();
        Scanner kb = new Scanner(System.in);
        int n = kb.nextInt();
        kb.nextLine();  // 남아 있는 줄바꿈 문자 제거
        String str = kb.nextLine();
        System.out.println(t.solution(n, str));
    }
}

다음은 관련 문제를 다룬 유사한 질문과 답변들입니다:

이 링크들에서 추가적인 예제와 설명을 참고하시면 도움이 될 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

0

19

1

갑자기 채점 사이트가 바뀌었어요

0

19

1

문제 리스트 페이지

0

22

1

채점 사이트 관련 질문드립니다

0

20

1

봉우리 문제 질문입니다

0

78

2

씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?

0

62

0

이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?

0

70

0

가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법

0

67

1

좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ

0

83

2

6-7 강의에서

0

47

1

6-6. 장난꾸러기 질문 있습니다.

0

43

1

강의 수강후 코딩테스트

0

106

1

answer 변수 사용 여부

0

42

1

2중 for문

1

83

2

2-11. 임시반장정하기 (Runtime Error)

0

62

1

혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?

0

68

1

이런 풀이는 어떨까요

0

42

1

자바 스트림 방식의 효율성 질문 드립니다.

0

55

1

알고리즘 자료 구조들..

0

60

1

StringBuilder vs BufferdWriter

0

47

1

원더랜드(프림)

0

47

1

이런 코드는 어떤가요?

0

59

1

bfs 풀이

0

55

1

병합정렬

0

55

1