inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-H

2-H 질문입니다

227

firdoo

작성한 질문수 9

0

제가 짠 코드가 예제출력은 맞게 나오는데 제출했을 때 틀렸다고 나옵니다.

강의 보기 전에 짠거라서 강사님과는 다른 방향으로 풀었지만 어디서 잘못됐는지 궁금합니다.

 

#include <iostream>
#include <string>
using namespace std;

string s;
int mo[21];
int cnt; 

int main(){
	while(true){
		cin >> s;
		cnt=0;
		if(s == "end") break;

		//s가 높은 품질이 아니면
		//1번째 조건
		if(s.find('a') && s.find('e') &&
		s.find('i') && s.find('o') && s.find('u') > 20){
			cnt += 1;
		}
		//2번째 조건 
		fill(&mo[0], &mo[0]+21, 0);
		for(int i=0; i<s.size(); i++){
			if(s[i] == 'a' || s[i] == 'e' || s[i] == 'i' || s[i] == 'o' || s[i] == 'u'){
				mo[i] = 1;
			}
			else{
				mo[i] = 2;
			} 
		}
		if(s.size()>=3){
			for(int i=0; i<s.size()-2; i++){
				if(mo[i] == mo[i+1] && mo[i+1] == mo[i+2]){
					cnt+=1;
				}
			}
		}
		
		//3번째 조건
		for(int i=0; i<s.size(); i++){
			if((s[i] == s[i+1]) && s[i] != 'e' && s[i] != 'o'){
				cnt += 1;
			}
		}
		//cnt가 1이라도 있으면 낮은 품질
		if(cnt>=1){
			cout << "<" << s << "> is not acceptable." << '\n';
		}
		//그렇지 않으면 높은 품질
		else{
			cout << "<" << s << "> is acceptable." << '\n';
		}
	}
	return 0;
}

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 firdoo님 ㅎㅎ

이 반례를 해결하지 못하는거 같아요.

kee

firdoo님 코드 :

<kee> is not acceptable.

 

정답은 acceptable이 나와야 합니다.

해당 부분의 로직 확인 부탁드립니다.

 

그리고 코드리뷰를 좀 드리면요.

		if(s.find('a') && s.find('e') &&
		s.find('i') && s.find('o') && s.find('u') > 20){
  1. 모음(a,e,i,o,u) 하나를 반드시 포함하여야 한다.

 

를 코드로 나타내신거 같은데 이부분이 좀 잘못된 거 같아요.

번역하자면 a, e, i, o의 위치 & u같은 경우 20번째 이후에 있어야 한다.. 이건데 좀 이상합니다.

일단 find를 통해 못찾을 경우 string::npos를 반환하는데

#include <bits/stdc++.h>
using namespace std; 
int main(){
	string a = "eeeeralodopa";
	cout << a.find("dopabb") << '\n'; 
	cout << bool(a.find("dopabb"))<< '\n'; 
	return 0;
}

이를 bool로 바꾸면 1이 나옵니다. 즉, false가 아니라는 것이죠.

 

 

또 질문 있으시면 질문 부탁드립니다.

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

감사합니다.

4 - A

0

22

2

코딩살구클럽 입장이 안됩니다

0

60

2

4-F 경우의 수 질문입니다.

0

32

2

코딩살구클럽 가입이 안됩니다.

0

74

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

54

1

교안 158페이지 문의드립니다

0

44

2

코딩살구클럽 관련 건의사항

0

114

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

44

1

진행 방법 질문드립니다!

0

80

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

63

2

2주차 개념#12 트리 순회

0

32

2

백준사이트가 종료된다고 합니다.

0

315

2

백준 서비스 종료

9

950

1

sk 하이닉스 코테 대비

0

385

2

3-G 최댓값 질문

0

54

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

84

2

3-I 코드 질문드립니다.

0

65

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

4-H 질문 있습니다 (코드 리뷰)

0

69

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

182

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

72

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

65

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

53

2