inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

2-H

2-H 비밀번호 발음하기 질문드립니다

285

ejksmile

작성한 질문수 3

0

안녕하세요!

궁금한 점이 있어서 질문 드립니다.

2-H 문제 해설에서 s[i]를 int형으로 반환해서 풀이하시던데 혹시 특별한 이유가 있을까요??

저는 s[i]를 그냥 char형으로 풀었습니다.

http://boj.kr/9de33b348bcb40ee958c4cfbc845c305

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 ejk님 ㅎㅎ

잘 푸셨네요. ㅎㅎ

bool isVowel(int idx){
	return (idx == 'a' || idx == 'e' || idx == 'i' || idx == 'o' || idx == 'u');
}
int main () { 
	while(true){
		cin >> s; 
		if(s == "end")break; 
		lcnt = vcnt = 0;
		bool flag = 0;
		bool is_include_v = 0;
		int prev = -1;
		for(int i = 0; i < s.size(); i++){
			int idx = s[i]; 
			if(isVowel(idx))lcnt++, vcnt = 0, is_include_v = 1;

이 부분 말씀하시는 거죠?

이문제에서는 딱히 의미는 없습니다.

다만, char형을 int형으로 바꾸면 좋을 때가 있습니다. 배열을 선언할 때인데요. 소문자 a는 97이기 때문에 만약 문제에서 소문자로 이루어진 값들이 나오고 이것들을 배열로 표현하면 97 + 26 이상의 배열이 필요합니다. 다만 이걸 int형으로 바꾸면서 'a' - 97 을 통해 좌표이동을 통해 26개의 배열만으로도 충분히 만들 수 있습니다.

 

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


0

ejksmile

안녕하세요! 답변 감사합니다 :)

그런데, 말씀해주신 이 부분이 잘 이해가 가지 않아서 다시 질문드립니다ㅠㅠ

"다만, char형을 int형으로 바꾸면 좋을 때가 있습니다. 배열을 선언할 때인데요. 소문자 a는 97이기 때문에 만약 문제에서 소문자로 이루어진 값들이 나오고 이것들을 배열로 표현하면 97 + 26 이상의 배열이 필요합니다. 다만 이걸 int형으로 바꾸면서 'a' - 97 을 통해 좌표이동을 통해 26개의 배열만으로도 충분히 만들 수 있습니다."

char arr[26] 과 int arr[26] 의 차이를 말씀하시는 걸까요? 아니면 소문자를 인덱스값으로 사용하는 배열을 쓸 때 (예를 들어, bool visited['a'], bool visited[(int)'a'])를 말씀하신 걸까요?

혹시 예시를 들어주실 수 있다면 감사하겠습니다.

0

큰돌

#include<bits/stdc++.h>
using namespace std;   
int main(){
    ios_base::sync_with_stdio(false); cin.tie(NULL);    
    cout.tie(NULL);
    char a = 'a';
    cout << (int)a << '\n';  
    cout << (int)a - 'a' << '\n'; 
    
     
    return 0; 
}

소문자를 인덱스값으로 사용하는 배열을 쓸 때

>> 네 이부분입니다. 앞의 코드처럼 'a'를 빼게 되면 0으로 표현할 수 있기 때문에 굳이 97 + 26개의 배열이 필요하지 않게 되는 것이죠.

 

감사합니다.

0

ejksmile

네 이해했습니다!

항상 친절히 답변해주셔서 감사합니다.

강의 너무 잘 듣고 있습니다 :)

코딩살구클럽 가입 문의

0

23

1

코딩 살구 클럽 컴파일 에러

0

17

1

추천 문제

0

18

1

코딩살구클럽 승인

0

24

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

31

2

문제를 고민하는 시간 관련

0

27

2

코딩살구클럽

0

42

2

코딩살구클럽 문의

0

45

2

코딩살구클럽 승인

0

37

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

35

2

3-F 채점 관련 질문

0

32

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

34

2

코딩살구클럽 승인

0

46

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

56

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

66

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3